AngularJS 如何在控制台进行错误调试


Posted in Javascript onJune 07, 2016

当我们在编写 AngularJS 的应用时,通过 Chrome, Firefox, 和 IE 的 JavaScript 控制台来获取隐藏在应用之中的数据(Data)和服务(Service) 是一件非常具有挑战性的工作。下面列出了一些简单的小窍门,可以帮助我们使用 Javascript 控制台来监视和控制一个正在运行的 Angular 应用,使其更加容易测试、修改甚至是实时的编写 Angular 应用。

1: 获取 Scopes (作用域)

我们可以使用一行 JS 代码来获取任何的 Scope (甚至是 isolated scopes) :

> angular.element(targetNode).scope()

-> ChildScope {$id: "005", this: ChildScope, $$listeners: Object, $$listenerCount: Object, $parent: Scope…}

或者获取 isolated scopes:

> angular.element(targetNode).isolateScope()

-> Scope {$id: "009", $$childTail: ChildScope, $$childHead: ChildScope, $$prevSibling: ChildScope, $$nextSibling: Scope…}

这里面的 targetNode 指的是 HTML Node(HTML节点)。你可以很容易的使用 document.querySelector() 来获取。

2: 监视 Scope Tree (作用域树)

为了更好的调试我们的应用,有些时候我们需要查看页面上的 Scope (作用域) 的结构师怎样的。这时候我们就需要使用 AngularJS
 Baratang 和 ng-inspector 这两个 Chrome 浏览器扩展来帮助我们实时查看 Scope (作用域) 的情况。并且,这两个扩展还有一些其他非常有用的功能。

    (1).AngularJS Baratang

AngularJS 如何在控制台进行错误调试

    (2).ng-inspector

AngularJS 如何在控制台进行错误调试

3: 抓取 Services (服务)

我们可以使用定义了 ngApp 元素的 injector 函数来抓取任何 Service (服务) 或者间接的通过任何带有 ng-scope class 的元素来获取 Service (服务)。

> angular.element(document.querySelector('html')).injector().get('MyService')

-> Object {undo: function, redo: function, _pushAction: function, newDocument: function, init: function…}

// Or slightly more generic

> angular.element(document.querySelector('.ng-scope')).injector().get('MyService')

接下来我们就可以使用相关的 Service 就像我们在程序中 injected(注入)过之后那样使用。

4: 从 directive 中获取 controller

有一些 directives (指令) 会将一些特定(通常是可以共用的)功能定义成为一个控制器。为了从控制台中获取一个指定 directive (指令) 的 controller (控制器) 示例, 我们只需要使用 controller() 函数。

> angular.element('my-pages').controller()

-> Constructor {}

最后一个不常用但是属于更高级的技巧。

5: Chrome Console(控制台) 特性

Chrome 有很多在 console (控制台) 中用于调试网页应用的非常好用的快捷命令。下面是对 Angular 开发最有帮助的一些命令:

    $0 - $4: 在 instpector window (监控器) 中获取最后的 5 个 DOM 元素。这个快捷方法可以非常方便的帮助我们来抓取选定元素的 scopes (作用域) : angular.element($0).scope()

    $(selector) 和 $$(selector): 可以方便的替代 querySelector() 和 querySelectorAll。

感谢 @zgohr 提供的这个小窍门!

总结

通过这些简单的小窍门,我们可以获取任意 scope (作用域) 中的数据、监控scope (作用域) 的层级、注入 services (服务) 并且 控制 directives (指令)。

所以下次,当你想要做一些微调、检查代码或者从控制台来控制一个 AngularJS 应用,我希望你能够像我一样记起这些小窍门并多加使用。

查看更多AngularJS的语法,大家可以关注:AngularJS 参考手册英文版,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS获取后台Cookies值的小例子
Mar 04 Javascript
浅谈js里面的InttoStr和StrtoInt
Jun 14 Javascript
详解MVC如何使用开源分页插件(shenniu.pager.js)
Dec 16 Javascript
jQuery实现弹幕效果
Feb 17 Javascript
用户管理的设计_jquery的ajax实现二级联动效果
Jul 13 jQuery
Angular服务Request异步请求的实例讲解
Aug 13 Javascript
element-ui 的el-button组件中添加自定义颜色和图标的实现方法
Oct 26 Javascript
layui 图片上传+表单提交+ Spring MVC的实例
Sep 21 Javascript
js实现整体缩放页面适配移动端
Mar 31 Javascript
详解Node.js使用token进行认证的简单示例
May 25 Javascript
基于postman获取动态数据过程详解
Sep 08 Javascript
react国际化react-intl的使用
May 06 Javascript
JQuery异步加载PartialView的方法
Jun 07 #Javascript
基于JS实现无缝滚动思路及代码分享
Jun 07 #Javascript
Bootstrap学习笔记之css样式设计(1)
Jun 07 #Javascript
jQuery hover事件简单实现同时绑定2个方法
Jun 07 #Javascript
PassWord输入框代码分享
Jun 07 #Javascript
Bootstrap学习笔记之css组件(3)
Jun 07 #Javascript
JavaScript判断数组重复内容的两种方法(推荐)
Jun 06 #Javascript
You might like
非常好用的Zend Framework分页类
2014/06/25 PHP
PHP多文件上传类实例
2015/03/07 PHP
php函数传值的引用传递注意事项分析
2016/06/25 PHP
PHP微信开发用Cache 解决数据缓存
2016/07/11 PHP
PHP基于imagick扩展实现合成图片的两种方法【附imagick扩展下载】
2017/11/14 PHP
PHP使用openssl扩展实现加解密方法示例
2020/02/20 PHP
js获得鼠标的坐标值的方法
2013/03/13 Javascript
Javascript selection的兼容性写法介绍
2013/12/20 Javascript
jquery动态加载js/css文件方法(自写小函数)
2014/10/11 Javascript
JavaScript实现标题栏文字轮播效果代码
2015/10/24 Javascript
JavaScript中数组去除重复的三种方法
2016/04/22 Javascript
手机移动端实现 jquery和HTML5 Canvas的幸运大奖盘特效
2016/12/06 Javascript
Vue.js 2.0学习教程之从基础到组件详解
2017/04/24 Javascript
AngularJS模糊查询功能实现代码(过滤内容下拉菜单排序过滤敏感字符验证判断后添加表格信息)
2017/10/24 Javascript
小程序的上传文件接口的注意要点解析
2019/09/17 Javascript
[43:58]DOTA2-DPC中国联赛定级赛 LBZS vs SAG BO3第一场 1月8日
2021/03/11 DOTA
Python版的文曲星猜数字游戏代码
2013/09/02 Python
Python pickle模块用法实例
2015/04/14 Python
Python批量转换文件编码格式
2015/05/17 Python
Python模块搜索概念介绍及模块安装方法介绍
2015/06/03 Python
使用Python读写文本文件及编写简单的文本编辑器
2016/03/11 Python
Python获取某一天是星期几的方法示例
2017/01/17 Python
利用python库在局域网内传输文件的方法
2018/06/04 Python
3分钟学会一个Python小技巧
2018/11/23 Python
Python标准库使用OrderedDict类的实例讲解
2019/02/14 Python
python反编译学习之字节码详解
2019/05/19 Python
python+selenium实现自动化百度搜索关键词
2019/06/03 Python
python 批量解压压缩文件的实例代码
2019/06/27 Python
Python简单处理坐标排序问题示例
2019/07/11 Python
Django异步任务线程池实现原理
2019/12/17 Python
tensorflow 报错unitialized value的解决方法
2020/02/06 Python
利用Python实现Excel的文件间的数据匹配功能
2020/06/16 Python
keras 自定义loss层+接受输入实例
2020/06/28 Python
教育科学研究生自荐信
2013/10/09 职场文书
公司综合部的成员自我评价分享
2013/11/05 职场文书
高中生物教学反思
2014/02/05 职场文书