国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

總結十個Angular.js由淺入深的面試問題

2019-11-20 09:08:46
字體:
來源:轉載
供稿:網友

一、ng-show/ng-hide 與 ng-if的區別?

我們都知道ng-show/ng-hide實際上是通過display來進行隱藏和顯示的。而ng-if實際上控制dom節點的增刪除來實現的。因此如果我們是根據不同的條件來進行dom節點的加載的話,那么ng-if的性能好過ng-show.

二、解釋下什么是$rootScrope以及和$scope的區別?

通俗的說$rootScrope 頁面所有$scope的父親。

我們來看下如何產生$rootScope$scope吧。

step1:Angular解析ng-app然后在內存中創建$rootScope。

step2:angular回繼續解析,找到{{}}表達式,并解析成變量。

step3:接著會解析帶有ng-controller的div然后指向到某個controller函數。這個時候在這個controller函數變成一個$scope對象實例。

三、表達式 {{yourModel}}是如何工作的?

它依賴于 $interpolation服務,在初始化頁面html后,它會找到這些表達式,并且進行標記,于是每遇見一個{{}},則會設置一個$watch。而$interpolation會返回一個帶有上下文參數的函數,最后該函數執行,則算是表達式$parse到那個作用域上。

四、Angular中的digest周期是什么?

每個digest周期中,angular總會對比scopemodel的值,一般digest周期都是自動觸發的,我們也可以使用$apply進行手動觸發。

五、 如何取消 $timeout, 以及停止一個$watch()?

停止 $timeout我們可以用cancel

var customTimeout = $timeout(function () {  // your code}, 1000);$timeout.cancel(customTimeout);

停掉一個$watch:

// .$watch() 會返回一個停止注冊的函數function that we store to a variable var deregisterWatchFn = $rootScope.$watch(‘someGloballyAvailableProperty', function (newVal) {  if (newVal) {  // we invoke that deregistration function, to disable the watch  deregisterWatchFn();  ... }});

六、Angular Directive中restrict 中分別可以怎樣設置?scope中@,=,&有什么區別?

restrict中可以分別設置:

     A匹配屬性

     E匹配標簽

     C匹配class

     M 匹配注釋

當然你可以設置多個值比如AEC,進行多個匹配。

scope中,@,=,&在進行值綁定時分別表示

     @獲取一個設置的字符串,它可以自己設置的也可以使用{{yourModel}}進行綁定的;

     = 雙向綁定,綁定scope上的一些屬性;

     & 用于執行父級scope上的一些表達式,常見我們設置一些需要執行的函數

angular.module('docsIsolationExample', []) .controller('Controller', ['$scope', function($scope) { $scope.alertName = function() {   alert('directive scope &'); }}]).directive('myCustomer', function() { return {  restrict: 'E',  scope: {   clickHandle: '&'  },  template: '<button ng-click="testClick()">Click Me</button>',  controller: function($scope) {   $scope.testClick = function() {    $scope.clickHandle();   }   } };});
<div ng-app="docsIsolationExample"> <div ng-controller="Controller">  <my-customer click-handle="alertName()"></my-customer></div>  </div>

< 進行單向綁定。

七、 列出至少三種實現不同模塊之間通信方式?

     1、Service

     2、events,指定綁定的事件

     3、使用 $rootScope

     4、controller之間直接使用$parent, $$childHead等

     5、directive 指定屬性進行數據綁定

八、有哪些措施可以改善Angular 性能

官方提倡的,關閉debug,$compileProvider

myApp.config(function ($compileProvider) {  $compileProvider.debugInfoEnabled(false);});

使用一次綁定表達式即{{::yourModel}}

減少watcher數量

在無限滾動加載中避免使用ng-repeat

使用性能測試的小工具去挖掘你的angular性能問題,我們可以使用簡單的console.time()也可以借助開發者工具以及Batarang

console.time("TimerName"); //your codeconsole.timeEnd("TimerName"); 

九、你認為在Angular中使用jQuery好么?

這是一個開放性的問題,盡管網上會有很多這樣的爭論,但是普遍還是認為這并不是一個特別好的嘗試。其實當我們學習Angular的時候,我們應該做到從0去接受angular的思想,數據綁定,使用angular自帶的一些api,合理的路由組織和,寫相關指令和服務等等。angular自帶了很多api可以完全替代掉jquery中常用的api,我們可以使用angular.element,$http,$timeout,ng-init等。

我們不妨再換個角度,如果業務需求,而對于一個新人(比較熟悉jQuery)的話,或許你引入jQuery可以讓它在解決問題,比如使用插件上有更多的選擇,當然這是通過影響代碼組織來提高工作效率,隨著對于angular理解的深入,在重構時會逐漸摒棄掉當初引入jquery時的一些代碼。(😂Po主就是這樣的人,希望不要被嘲笑,業務卻是趕著走)

所以我覺得兩種框架說完全不能一起用肯定是錯的,但是我們還是應該盡力去遵循angular的設計。

十、如何進行angular的單元測試

我們可以使用karam+jasmine 進行單元測試,我們通過ngMock引入angular app然后自行添加我們的測試用例。 一段簡單的測試代碼:

describe('calculator', function () { beforeEach(module('calculatorApp')); var $controller; beforeEach(inject(function(_$controller_){  $controller = _$controller_; })); describe('sum', function () {    it('1 + 1 should equal 2', function () {      var $scope = {};      var controller = $controller('CalculatorController', { $scope: $scope });      $scope.x = 1;      $scope.y = 2;      $scope.sum();      expect($scope.z).toBe(3);    });    });});

十一、總結

以上就是這篇文章的全部內容了,希望對大家的學習和工作能有所幫助。如果有疑問可以留言討論。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 团风县| 天津市| 青岛市| 罗定市| 盈江县| 达州市| 建阳市| 任丘市| 射洪县| 七台河市| 颍上县| 繁峙县| 昆山市| 库车县| 临漳县| 应用必备| 磐安县| 武乡县| 偏关县| 博湖县| 平顶山市| 荣昌县| 龙海市| 彩票| 定襄县| 锡林郭勒盟| 准格尔旗| 黎城县| 郧西县| 新巴尔虎右旗| 中方县| 成安县| 古交市| 宁远县| 饶河县| 吉隆县| 全南县| 青龙| 紫金县| 玉田县| 通渭县|