使用Chrome浏览器调试AngularJS应用的方法


Posted in Javascript onJune 18, 2015

当我们构建AngularJS应用时,通过浏览器(如Chrome,Firefox和IE)的JavaScript控制台访问应用中隐藏的数据和服务总会有些困难。下面是一些简单的技巧可以帮助我们通过Javascript控制台来查看或者控制正在运行的Angular应用,使得应用可以比较容易进行测试,修改,甚至实时的修改我们的Angular应用:
1: 访问作用域

通过一行简单的JS程序访问页面中任何作用域(甚至是隔离的作用域!):
 

> angular.element(targetNode).scope()
-> ChildScope {$id: "005", this: ChildScope, $$listeners: Object, $$listenerCount: Object, $parent: Scope…}

对于隔离作用域:

> angular.element(targetNode).isolateScope()
-> Scope {$id: "009", $$childTail: ChildScope, $$childHead: ChildScope, $$prevSibling: ChildScope, $$nextSibling: Scope…}

这里用`targetNode`作为HTML节点的引用。你可以非常轻松的通过`document.querySelector()`来创建一个`targetNode`

2:查看作用域树

有些时候,我们需要查看页面中作用域层次来有效的调试我们的应用。AngularJS Batarang正是我们需要的一款Chrome浏览器的扩展,可以展示当前作用域层次,并具有其他非常有用的特性。

使用Chrome浏览器调试AngularJS应用的方法

3: 抓取任何服务

无论ngApp在哪里定义,我们都可以使用注入器功能来抓取任何的服务的引用(如果使用angular的bootstrap方法,则可以手动抓取$rootElement):
 

> angular.element('html').injector().get('MyService')
-> Object {undo: function, redo: function, _pushAction: function, newDocument: function, init: function…}

然后我们就可以对该服务进行调用,就像我们可以将服务注入一样。

4: 访问控制器使用指令

一些指令定义了一个拥有某些额外(通常是分享)功能的控制器。为了从控制台访问一个给定指令的控制器实例,只需使用 controller() 方法:

> angular.element('my-pages').controller()
-> Constructor {}

最后一种做法更高级并且不常用。
5: Chrome 控制台特性

Chrome浏览器的控制台有一堆不错的捷径 来调试浏览器应用。这是一些Angular开发中最好的做法:

  •     $0-$4: 访问最近在查看窗口中进行选取的 5 个DOM元素。选择抓取的范围非常方便。
  •     $(selector)和$$(selector): 分别是querySelector() 和 querySelectorAll的一个快速的替代

感谢 @zgohr 提供这种方法!

结论

通过几个简单的技巧,我们可以访问页面任何作用域中的数据,查看作用域层次结构,注入服务和控制指令。

所以下一次,如果你想稍微进行调整,检查自己的工作或者通过控制台控制AngularJS一个用,我希望你能记住这些命令,并且能做到像我一样觉得他们非常实用!

Javascript 相关文章推荐
jQuery代码优化之基本事件
Nov 01 Javascript
JavaScript让Textarea支持tab按键的方法
Jun 26 Javascript
javascript实现类似百度分享功能的方法
Jul 27 Javascript
javascript实现状态栏中文字动态显示的方法
Oct 20 Javascript
Node.js 实现简单小说爬虫实例
Nov 18 Javascript
AngularJS使用带属性值的ng-app指令实现自定义模块自动加载的方法
Jan 04 Javascript
Bootstrap警告(Alerts)的实现方法
Mar 22 Javascript
详解利用jsx写vue组件的方法示例
Jul 17 Javascript
TypeScript开发Node.js程序的方法
Apr 30 Javascript
JavaScript实现图片上传并预览并提交ajax
Sep 30 Javascript
VUE UPLOAD 通过ACTION返回上传结果操作
Sep 07 Javascript
el-table-column 内容不自动换行的解决方法
Aug 14 Vue.js
使用AngularJS创建自定义的过滤器的方法
Jun 18 #Javascript
深入讲解AngularJS中的自定义指令的使用
Jun 18 #Javascript
3个可以改善用户体验的AngularJS指令介绍
Jun 18 #Javascript
在AngularJS应用中实现一些动画效果的代码
Jun 18 #Javascript
使用AngularJS对路由进行安全性处理的方法
Jun 18 #Javascript
浅谈Node.js中的定时器
Jun 18 #Javascript
浅析AngularJS中的生命周期和延迟处理
Jun 18 #Javascript
You might like
ob_start(),ob_start('ob_gzhandler')使用
2006/12/25 PHP
php header功能的使用
2013/10/28 PHP
php的hash算法介绍
2014/02/13 PHP
jquery+php+ajax显示上传进度的多图片上传并生成缩略图代码
2014/10/15 PHP
Symfony实现行为和模板中取得request参数的方法
2016/03/17 PHP
php对接java现实加签验签的实例
2016/11/25 PHP
JavaScript使用setInterval()函数实现简单轮询操作的方法
2015/02/02 Javascript
JS动态修改iframe高度和宽度的方法
2015/04/01 Javascript
JavaScript中字符串与Unicode编码互相转换的实现方法
2015/12/18 Javascript
Node.js的npm包管理器基础使用教程
2016/05/26 Javascript
WebPack基础知识详解
2017/01/16 Javascript
原生JS实现左右箭头选择日期实例代码
2017/03/14 Javascript
学习使用Bootstrap页面排版样式
2017/05/11 Javascript
javascript 日期相减-在线教程(附代码)
2017/08/17 Javascript
js事件on动态绑定数据,绑定多个事件的方法
2018/09/15 Javascript
js中null与空字符串""的区别讲解
2019/01/17 Javascript
JavaScript实现鼠标移入随机变换颜色
2020/11/24 Javascript
[03:21]辉夜杯主赛事 12月25日TOP5
2015/12/26 DOTA
实例讲解python函数式编程
2014/06/09 Python
浅谈Python数据类型判断及列表脚本操作
2016/11/04 Python
用yum安装MySQLdb模块的步骤方法
2016/12/15 Python
Sanic框架配置操作分析
2018/07/17 Python
DRF跨域后端解决之django-cors-headers的使用
2019/01/27 Python
Python利用scapy实现ARP欺骗的方法
2019/07/23 Python
基于Tensorflow:CPU性能分析
2020/02/10 Python
Python批量安装卸载1000个apk的方法
2020/04/10 Python
Python实现自动打开电脑应用的示例代码
2020/04/17 Python
英国羊绒服装购物网站:Pure Collection
2018/10/22 全球购物
英国电气世界:Electrical World
2019/09/08 全球购物
机电专业毕业生推荐信
2013/11/10 职场文书
蟋蟀的住宅教学反思
2014/04/26 职场文书
大学生求职意向书
2015/05/11 职场文书
廉洁自律证明
2015/06/24 职场文书
2015重阳节座谈会主持词
2015/07/30 职场文书
劳动保障事务所个人工作总结
2015/08/12 职场文书
如何利用python和DOS获取wifi密码
2021/03/31 Python