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 屏蔽键盘不可用与鼠标右键不可用的方法
Nov 18 Javascript
jquery实现的图片点击滚动效果
Apr 29 Javascript
jQuery中:visible选择器用法实例
Dec 30 Javascript
纯JS实现弹性导航条效果
Mar 06 Javascript
js实现首屏延迟加载实现方法 js实现多屏单张图片延迟加载效果
Jul 17 Javascript
使用JavaScript实现表格编辑器(实例讲解)
Aug 02 Javascript
vuejs使用$emit和$on进行组件之间的传值的示例
Oct 04 Javascript
使用Vue动态生成form表单的实例代码
Apr 26 Javascript
Angularjs之如何在跨域请求中传输Cookie的方法
Jun 01 Javascript
layui实现根据table数据判断按钮显示情况的方法
Sep 26 Javascript
vue fetch中的.then()的正确使用方法
Apr 17 Javascript
解决vue-cli输入命令vue ui没效果的问题
Nov 17 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
攻克CakePHP系列一 连接MySQL数据库
2008/10/22 PHP
php配置php-fpm启动参数及配置详解
2013/11/04 PHP
Php无限级栏目分类读取的实现代码
2014/02/19 PHP
PHP统一页面编码避免乱码问题
2015/04/09 PHP
浅谈PHP eval()函数定义和用法
2016/06/21 PHP
thinkphp Apache配置重启Apache1 restart 出错解决办法
2017/02/15 PHP
HTML中Select不用Disabled实现ReadOnly的效果
2008/04/07 Javascript
ajax 文件上传应用简单实现
2009/03/03 Javascript
点击文章内容处弹出页面代码
2009/10/01 Javascript
File, FileReader 和 Ajax 文件上传实例分析(php)
2011/04/27 Javascript
jQuery EasyUI API 中文文档 - DataGrid数据表格
2011/11/17 Javascript
关于编写性能高效的javascript事件的技术
2014/11/28 Javascript
举例说明如何为JavaScript的方法参数设置默认值
2015/11/17 Javascript
bootstrap的常用组件和栅格式布局详解
2017/05/02 Javascript
Nodejs处理异常操作示例
2018/12/25 NodeJs
vue增加强缓存和版本号的实现方法
2019/05/01 Javascript
微信小程序上传图片并等比列压缩到指定大小的实例代码
2019/10/24 Javascript
vue 需求 data中的数据之间的调用操作
2020/08/05 Javascript
Python __setattr__、 __getattr__、 __delattr__、__call__用法示例
2015/03/06 Python
Django中实现点击图片链接强制直接下载的方法
2015/05/14 Python
python中map()与zip()操作方法
2016/02/27 Python
python编程实现希尔排序
2017/04/13 Python
你不知道的葡萄干处理法、橙蜜处理法、二氧化碳酵母法
2021/03/17 冲泡冲煮
Origins加拿大官网:雅诗兰黛集团高端植物护肤品牌
2017/11/19 全球购物
英国高街电视:High Street TV
2018/05/22 全球购物
美国杰西潘尼官网:JCPenney
2019/06/12 全球购物
罗技美国官网:Logitech美国
2020/01/22 全球购物
什么是JNDI的上下文?如何初始化JNDI上下文
2012/03/10 面试题
XMLHttpRequest对象在IE和Firefox中创建方式有没有不同
2016/03/23 面试题
《蜗牛的奖杯》教后反思
2014/04/24 职场文书
心得体会的写法
2014/09/05 职场文书
房产公证委托书范本
2014/09/20 职场文书
仓管员岗位职责范本
2015/04/01 职场文书
一个都不能少观后感
2015/06/04 职场文书
JavaWeb Servlet实现网页登录功能
2021/07/04 Java/Android
Spring Boot 整合 Apache Dubbo的示例代码
2021/07/04 Java/Android