源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

总结十个Angular.js由浅入深的面试问题

  • 时间:2020-10-13 11:31 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:总结十个Angular.js由浅入深的面试问题
[b]一、ng-show/ng-hide 与 ng-if的区别? [/b] 我们都知道[code]ng-show/ng-hide[/code]实际上是通过[code]display[/code]来进行隐藏和显示的。而[code]ng-if[/code]实际上控制[code]dom[/code]节点的增删除来实现的。因此如果我们是根据不同的条件来进行[code]dom[/code]节点的加载的话,那么[code]ng-if[/code]的性能好过[code]ng-show[/code]. [b]二、解释下什么是$rootScrope以及和$scope的区别?[/b] 通俗的说[code]$rootScrope[/code] 页面所有[code]$scope[/code]的父亲。 [img]http://files.jb51.net/file_images/article/201608/2016826110341589.png?201672611352[/img] 我们来看下如何产生[code]$rootScope[/code]和[code]$scope[/code]吧。 step1:Angular解析[code]ng-app[/code]然后在内存中创建[code]$rootScope[/code]。 step2:angular回继续解析,找到[code]{{}}[/code]表达式,并解析成变量。 step3:接着会解析带有[code]ng-controller[/code]的div然后指向到某个[code]controller[/code]函数。这个时候在这个[code]controller[/code]函数变成一个[code]$scope[/code]对象实例。 [b]三、表达式 {{yourModel}}是如何工作的?[/b] 它依赖于 [code]$interpolation[/code]服务,在初始化页面html后,它会找到这些表达式,并且进行标记,于是每遇见一个[code]{{}}[/code],则会设置一个[code]$watch[/code]。而[code]$interpolation[/code]会返回一个带有上下文参数的函数,最后该函数执行,则算是表达式[code]$parse[/code]到那个作用域上。 [b]四、Angular中的digest周期是什么?[/b] 每个[code]digest[/code]周期中,angular总会对比[code]scope[/code]上[code]model[/code]的值,一般[code]digest[/code]周期都是自动触发的,我们也可以使用[code]$apply[/code]进行手动触发。 [b]五、 如何取消 $timeout, 以及停止一个$watch()?[/b] 停止 [code]$timeout[/code]我们可以用[code]cancel[/code]:
var customTimeout = $timeout(function () { 
 // your code
}, 1000);

$timeout.cancel(customTimeout);
[b]停掉一个$watch:[/b]
// .$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();
  ...
 }
});
[b]六、Angular Directive中restrict 中分别可以怎样设置?scope中@,=,&有什么区别?[/b] [code]restrict[/code]中可以分别设置:      A匹配属性      E匹配标签      C匹配class      M 匹配注释 当然你可以设置多个值比如[code]AEC[/code],进行多个匹配。 在[code]scope[/code]中,@,=,&在进行值绑定时分别表示      @获取一个设置的字符串,它可以自己设置的也可以使用[code]{{yourModel}}[/code]进行绑定的;      = 双向绑定,绑定[code]scope[/code]上的一些属性;      & 用于执行父级[code]scope[/code]上的一些表达式,常见我们设置一些需要执行的函数
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>
< 进行单向绑定。 [b]七、 列出至少三种实现不同模块之间通信方式?[/b]      1、Service      2、events,指定绑定的事件      3、使用 $rootScope      4、controller之间直接使用$parent, $$childHead等      5、directive 指定属性进行数据绑定 [b]八、有哪些措施可以改善Angular 性能[/b] 官方提倡的,关闭[code]debug[/code],[code]$compileProvider[/code]
myApp.config(function ($compileProvider) { 
 $compileProvider.debugInfoEnabled(false);
});
使用一次绑定表达式即[code]{{::yourModel}}[/code] 减少watcher数量 在无限滚动加载中避免使用[code]ng-repeat[/code] 使用性能测试的小工具去挖掘你的angular性能问题,我们可以使用简单的[code]console.time()[/code]也可以借助开发者工具以及[code]Batarang[/code]
console.time("TimerName"); 
//your code
console.timeEnd("TimerName"); 
[b]九、你认为在Angular中使用jQuery好么?[/b] 这是一个开放性的问题,尽管网上会有很多这样的争论,但是普遍还是认为这并不是一个特别好的尝试。其实当我们学习Angular的时候,我们应该做到从0去接受angular的思想,数据绑定,使用angular自带的一些api,合理的路由组织和,写相关指令和服务等等。angular自带了很多api可以完全替代掉jquery中常用的api,我们可以使用angular.element,$http,$timeout,ng-init等。 我们不妨再换个角度,如果业务需求,而对于一个新人(比较熟悉jQuery)的话,或许你引入jQuery可以让它在解决问题,比如使用插件上有更多的选择,当然这是通过影响代码组织来提高工作效率,随着对于angular理解的深入,在重构时会逐渐摒弃掉当初引入jquery时的一些代码。(😂Po主就是这样的人,希望不要被嘲笑,业务却是赶着走) 所以我觉得两种框架说完全不能一起用肯定是错的,但是我们还是应该尽力去遵循angular的设计。 [b]十、如何进行angular的单元测试[/b] 我们可以使用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);
    });  
  });

});
[b]十一、总结[/b] 以上就是这篇文章的全部内容了,希望对大家的学习和工作能有所帮助。如果有疑问可以留言讨论。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部