欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-05-14 17:38:39
当我们在编写 angularjs 的应用时,通过 chrome, firefox, 和 ie 的 javascript 控制台来获取隐藏在应用之中的数据(data)和服务(...

当我们在编写 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 参考手册英文版,也希望大家多多支持。