虽然只有10个问题,可是覆盖了angular开发中的各个方面,有基本的知识点,也有在开发过程当中碰见的问题,同时也有较为开放性的问题去辨别面试者的基础水准和项目经验若是本身一年前面试确定是喜剧到悲剧的转变?。(PS:答案仅供参考~)。javascript
ng-show/ng-hide
与 ng-if
的区别?咱们都知道ng-show/ng-hide其实是经过display
来进行隐藏和显示的。而ng-if实际上控制dom节点的增删除来实现的。所以若是咱们是根据不一样的条件来进行dom节点的加载的话,那么ng-if的性能好过ng-show.html
$rootScrope
以及和$scope
的区别?通俗的说$rootScrope
页面全部$scope
的父亲
。vue
咱们来看下如何产生$rootScope
和$scope
吧。java
step1:Angular解析ng-app
而后在内存中建立$rootScope
。jquery
step2:angular回继续解析,找到{{}}
表达式,并解析成变量。git
step3:接着会解析带有ng-controller
的div而后指向到某个controller函数。这个时候在这个controller函数变成一个$scope对象实例。angularjs
{{yourModel}}
是如何工做的?它依赖于 $interpolation服务,在初始化页面html后,它会找到这些表达式,而且进行标记,因而每碰见一个{{}}
,则会设置一个$watch
。而$interpolation
会返回一个带有上下文参数的函数,最后该函数执行,则算是表达式$parse
到那个做用域上。github
每一个digest周期中,angular总会对比scope上model的值,通常digest周期都是自动触发的,咱们也可使用$apply进行手动触发。更深层次的研究,能够移步The Digest Loop and apply。web
$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(); ... } });
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>
<
进行单向绑定。
Service
events,指定绑定的事件
使用 $rootScope
controller之间直接使用$parent
, $$childHead
等
directive 指定属性进行数据绑定
官方提倡的,关闭debug,$compileProvider
myApp.config(function ($compileProvider) { $compileProvider.debugInfoEnabled(false); });
使用一次绑定表达式即{{::yourModel}}
减小watcher数量
在无限滚动加载中避免使用ng-repeat,关于解决方法能够参考这篇文章
使用性能测试的小工具去挖掘你的angular性能问题,咱们可使用简单的console.time()
也能够借助开发者工具以及Batarang
console.time("TimerName"); //your code console.timeEnd("TimerName");
这是一个开放性的问题,尽管网上会有不少这样的争论,可是广泛仍是认为这并非一个特别好的尝试。其实当咱们学习Angular的时候,咱们应该作到从0去接受angular的思想,数据绑定,使用angular自带的一些api,合理的路由组织和,写相关指令和服务等等。angular自带了不少api能够彻底替代掉jquery中经常使用的api,咱们可使用angular.element
,$http
,$timeout
,ng-init
等。
咱们不妨再换个角度,若是业务需求,而对于一个新人(比较熟悉jQuery)的话,或许你引入jQuery可让它在解决问题,好比使用插件上有更多的选择,固然这是经过影响代码组织来提升工做效率,随着对于angular理解的深刻,在重构时会逐渐摒弃掉当初引入jquery时的一些代码。(?Po主就是这样的人,但愿不要被嘲笑,业务倒是赶着走)
因此我以为两种框架说彻底不能一块儿用确定是错的,可是咱们仍是应该尽力去遵循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); }); }); });
关于测试,你们能够看下使用karma进行angular测试
除了Karam , Angular.js团队推出了一款e2e(end-to-end)的测试框架protractor
本文同步博客:http://www.jackpu.com/shi-ge-jing-chang-yu-jian-de-angular-jsmian-shi-wen-ti/