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


Posted in Javascript onAugust 26, 2016

一、ng-show/ng-hide 与 ng-if的区别?

我们都知道ng-show/ng-hide实际上是通过display来进行隐藏和显示的。而ng-if实际上控制dom节点的增删除来实现的。因此如果我们是根据不同的条件来进行dom节点的加载的话,那么ng-if的性能好过ng-show.

二、解释下什么是$rootScrope以及和$scope的区别?

通俗的说$rootScrope 页面所有$scope的父亲。

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

我们来看下如何产生$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 code
console.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);
    });  
  });

});

十一、总结

以上就是这篇文章的全部内容了,希望对大家的学习和工作能有所帮助。如果有疑问可以留言讨论。

Javascript 相关文章推荐
jQuery 阴影插件代码分享
Jan 09 Javascript
使用UglifyJS合并/压缩JavaScript的方法
Mar 07 Javascript
js判断undefined类型,undefined,null, 的区别详细解析
Dec 16 Javascript
使用delegate方法为一个tr标签加一个链接
Jun 27 Javascript
jquery实现鼠标滑过小图查看大图的方法
Jul 20 Javascript
页面get请求 中文参数方法乱码问题的快速解决方法
May 31 Javascript
完美解决jQuery的hover事件在IE中不停闪动的问题
Feb 10 Javascript
jQuery+C#实现参数RSA加密传输功能【附jsencrypt.js下载】
Jun 26 jQuery
解决vue中post方式提交数据后台无法接收的问题
Aug 11 Javascript
Vue中使用方法、计算属性或观察者的方法实例详解
Oct 31 Javascript
vue 实现移动端键盘搜索事件监听
Nov 06 Javascript
JS函数进阶之prototy用法实例分析
Jan 15 Javascript
Jquery遍历select option和添加移除option的实现方法
Aug 26 #Javascript
响应式表格之固定表头的简单实现
Aug 26 #Javascript
jQuery基于BootStrap样式实现无限极地区联动
Aug 26 #Javascript
BootStrap无限级分类(无限极分类封装版)
Aug 26 #Javascript
jquery 动态合并单元格的实现方法
Aug 26 #Javascript
轻松掌握JavaScript中介者模式
Aug 26 #Javascript
修改jquery中dialog的title属性方法(推荐)
Aug 26 #Javascript
You might like
深入Memcache的Session数据的多服务器共享详解
2013/06/13 PHP
php实现微信和支付宝支付的示例代码
2020/08/11 PHP
基于php解决json_encode中文UNICODE转码问题
2020/11/10 PHP
jquery实现每个数字上都带进度条的幻灯片
2013/02/20 Javascript
jQuery的css()方法用法实例
2014/12/24 Javascript
Jquery幻灯片特效代码分享--打开页面随机选择切换方式(3)
2015/08/15 Javascript
18个非常棒的jQuery代码片段
2015/11/02 Javascript
JCrop+ajaxUpload 图像切割上传的实例代码
2016/07/20 Javascript
微信小程序 数据遍历的实现
2017/04/05 Javascript
jQuery实现动画、消失、显现、渐出、渐入效果示例
2018/09/06 jQuery
微信小程序适配iphoneX的实现方法
2018/09/18 Javascript
vue如何安装使用Quill富文本编辑器
2018/09/21 Javascript
JavaScript数组排序小程序实现解析
2020/01/13 Javascript
Node.js 中如何收集和解析命令行参数
2021/01/08 Javascript
Python学习笔记(一)(基础入门之环境搭建)
2014/06/05 Python
Python中的tuple元组详细介绍
2015/02/02 Python
Python 两个列表的差集、并集和交集实现代码
2016/09/21 Python
Python使用django框架实现多人在线匿名聊天的小程序
2017/11/29 Python
python 提取key 为中文的json 串方法
2018/12/31 Python
对python中list的拷贝与numpy的array的拷贝详解
2019/01/29 Python
Python实现的远程文件自动打包并下载功能示例
2019/07/12 Python
Python实现微信机器人的方法
2019/09/06 Python
Tensorflow轻松实现XOR运算的方式
2020/02/03 Python
在python中使用pymysql往mysql数据库中插入(insert)数据实例
2020/03/02 Python
Python xlrd excel文件操作代码实例
2020/03/10 Python
基于python3.7利用Motor来异步读写Mongodb提高效率(推荐)
2020/04/29 Python
python 下载文件的几种方法汇总
2021/01/06 Python
python中Pexpect的工作流程实例讲解
2021/03/02 Python
电子信息毕业生自荐信
2013/11/16 职场文书
考试作弊被抓检讨书
2014/01/10 职场文书
小学生开学第一课活动方案
2014/03/27 职场文书
乡镇党员干部群众路线对照检查材料思想汇报
2014/09/28 职场文书
2015年度质量工作总结报告
2015/04/27 职场文书
2015年小学校长工作总结
2015/05/19 职场文书
62句有关感恩节文案(推荐收藏)
2019/11/28 职场文书
Mysql将字符串按照指定字符分割的正确方法
2022/05/30 MySQL