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 相关文章推荐
xmlHTTP实例
Oct 24 Javascript
向大师们学习Javascript(视频与PPT)
Dec 27 Javascript
JQuery中层次选择器用法实例详解
May 18 Javascript
jQuery实现首页图片淡入淡出效果的方法
Jun 10 Javascript
JavaScript中的Math.E属性使用详解
Jun 12 Javascript
js读取并解析JSON类型数据的方法
Nov 14 Javascript
jQuery+canvas实现的球体平抛及颜色动态变换效果
Jan 28 Javascript
基于JavaScript 性能优化技巧心得(分享)
Dec 11 Javascript
JS加密插件CryptoJS实现AES加密操作示例
Aug 16 Javascript
JavaScript对象拷贝与赋值操作实例分析
Dec 10 Javascript
利用原生JS实现data方法示例代码
May 28 Javascript
JavaScript面向对象程序设计中对象的定义和继承详解
Jul 29 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
PHP 日期加减的类,很不错
2009/10/10 PHP
php中对2个数组相加的函数
2011/06/24 PHP
MySQL时间字段究竟使用INT还是DateTime的说明
2012/02/27 PHP
一个PHP的ZIP压缩类分享
2014/05/04 PHP
php定义一个参数带有默认值的函数实例分析
2015/03/16 PHP
Yii2 rbac权限控制之rule教程详解
2016/06/23 PHP
微信公众号开发之文本消息自动回复php代码
2016/08/08 PHP
php判断是否连接上网络的方法实例详解
2016/12/14 PHP
TP(thinkPHP)框架多层控制器和多级控制器的使用示例
2018/06/13 PHP
RR vs IO BO3 第一场2.13
2021/03/10 DOTA
Javascript Math对象
2009/08/13 Javascript
javascript学习笔记(四) Number 数字类型
2012/06/19 Javascript
js的hasownproperty使用示例
2014/03/02 Javascript
常用的Javascript数据验证插件
2015/08/04 Javascript
easyui中combotree循环获取父节点至根节点并输出路径实现方法
2016/11/10 Javascript
详解angularjs中如何实现控制器和指令之间交互
2017/05/31 Javascript
解决webpack打包速度慢的解决办法汇总
2017/07/06 Javascript
AngularJs 最新验证手机号码的实例,成功测试通过
2017/11/26 Javascript
浅谈vue项目4rs vue-router上线后history模式遇到的坑
2018/09/27 Javascript
详解原生JS动态添加和删除类
2019/03/26 Javascript
taro开发微信小程序的实践
2019/05/21 Javascript
解决vue项目运行提示Warnings while compiling.警告的问题
2020/09/18 Javascript
用Python编写简单的定时器的方法
2015/05/02 Python
django ObjectDoesNotExist 和 DoesNotExist的用法
2020/07/09 Python
Python操作Elasticsearch处理timeout超时
2020/07/17 Python
django和flask哪个值得研究学习
2020/07/31 Python
如何使用python-opencv批量生成带噪点噪线的数字验证码
2020/12/21 Python
美体小铺加拿大官方网站:The Body Shop加拿大
2016/10/30 全球购物
params有什么用
2016/03/01 面试题
广州足迹信息技术有限公司Java软件工程师试题
2014/02/15 面试题
护士辞职信范文
2014/01/19 职场文书
部队万能检讨书
2014/02/20 职场文书
技术岗位竞聘演讲稿
2014/05/16 职场文书
机电一体化毕业生自荐信
2014/06/19 职场文书
PostgreSQL基于pgrouting的路径规划处理方法
2022/04/18 PostgreSQL
css3手动实现pc端横向滚动
2022/06/21 HTML / CSS