angular.js在控制台怎么调试
2016-01-27 · 知道合伙人数码行家
huanglenzhi
知道合伙人数码行家
向TA提问 私信TA
知道合伙人数码行家
采纳数:117538
获赞数:517201
长期从事计算机组装,维护,网络组建及管理。对计算机硬件、操作系统安装、典型网络设备具有详细认知。
向TA提问 私信TA
关注
展开全部
1: 获取 Scopes (作用域)
我们可以使用一行 JS 代码来获取任何的 Scope (甚至是 isolated scopes) :
<code class="language-javascript">> angular.element(targetNode).scope()
-> ChildScope {$id: 005, this: ChildScope, $$listeners: Object, $$listenerCount: Object, $parent: Scope…}
</code>
或者获取 isolated scopes:
<code class="language-javascript">> angular.element(targetNode).isolateScope()
-> Scope {$id: 009, $$childTail: ChildScope, $$childHead: ChildScope, $$prevSibling: ChildScope, $$nextSibling: Scope…}
</code>
这里面的 targetNode 指的是 HTML Node(HTML节点)。你可以很容易的使用document.querySelector() 来获取。
2: 监视 Scope Tree (作用域树)
为了更好的调试我们的应用,有些时候我们需要查看页面上的 Scope (作用域) 的结构师怎样的。这时候我们就需要使用 AngularJS Baratang 和 ng-inspector 这两个 Chrome 浏览器扩展来帮助我们实时查看 Scope (作用域) 的情况。并且,这两个扩展还有一些其他非常有用的功能。
AngularJS Baratang
ng-inspector
3: 抓取 Services (服务)
我们可以使用定义了 ngApp 元素的 injector 函数来抓取任何 Service (服务) 或者间接的通过任何带有 ng-scope class 的元素来获取 Service (服务)。
<code class="language-javascript">> 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')
</code>
接下来我们就可以使用相关的 Service 就像我们在程序中 injected(注入)过之后那样使用。
4: 从 directive 中获取 controller
有一些 directives (指令) 会将一些特定(通常是可以共用的)功能定义成为一个控制器。为了从控制台中获取一个指定 directive (指令) 的 controller (控制器) 示例, 我们只需要使用controller() 函数。
<code class="language-javascript">> angular.element('my-pages').controller()
-> Constructor {}
</code>
最后一个不常用但是属于更高级的技巧。
5: Chrome Console(控制台) 特性
Chrome 有很多在 console (控制台) 中用于调试网页应用的非常好用的快捷命令。下面是对 Angular 开发最有帮助的一些命令:
$0 - $4: 在 instpector window (监控器) 中获取最后的 5 个 DOM 元素。这个快捷方法可以非常方便的帮助我们来抓取选定元素的 scopes (作用域) : angular.element($0).scope()
$(selector) 和 $$(selector): 可以方便的替代 querySelector() 和 querySelectorAll。
我们可以使用一行 JS 代码来获取任何的 Scope (甚至是 isolated scopes) :
<code class="language-javascript">> angular.element(targetNode).scope()
-> ChildScope {$id: 005, this: ChildScope, $$listeners: Object, $$listenerCount: Object, $parent: Scope…}
</code>
或者获取 isolated scopes:
<code class="language-javascript">> angular.element(targetNode).isolateScope()
-> Scope {$id: 009, $$childTail: ChildScope, $$childHead: ChildScope, $$prevSibling: ChildScope, $$nextSibling: Scope…}
</code>
这里面的 targetNode 指的是 HTML Node(HTML节点)。你可以很容易的使用document.querySelector() 来获取。
2: 监视 Scope Tree (作用域树)
为了更好的调试我们的应用,有些时候我们需要查看页面上的 Scope (作用域) 的结构师怎样的。这时候我们就需要使用 AngularJS Baratang 和 ng-inspector 这两个 Chrome 浏览器扩展来帮助我们实时查看 Scope (作用域) 的情况。并且,这两个扩展还有一些其他非常有用的功能。
AngularJS Baratang
ng-inspector
3: 抓取 Services (服务)
我们可以使用定义了 ngApp 元素的 injector 函数来抓取任何 Service (服务) 或者间接的通过任何带有 ng-scope class 的元素来获取 Service (服务)。
<code class="language-javascript">> 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')
</code>
接下来我们就可以使用相关的 Service 就像我们在程序中 injected(注入)过之后那样使用。
4: 从 directive 中获取 controller
有一些 directives (指令) 会将一些特定(通常是可以共用的)功能定义成为一个控制器。为了从控制台中获取一个指定 directive (指令) 的 controller (控制器) 示例, 我们只需要使用controller() 函数。
<code class="language-javascript">> angular.element('my-pages').controller()
-> Constructor {}
</code>
最后一个不常用但是属于更高级的技巧。
5: Chrome Console(控制台) 特性
Chrome 有很多在 console (控制台) 中用于调试网页应用的非常好用的快捷命令。下面是对 Angular 开发最有帮助的一些命令:
$0 - $4: 在 instpector window (监控器) 中获取最后的 5 个 DOM 元素。这个快捷方法可以非常方便的帮助我们来抓取选定元素的 scopes (作用域) : angular.element($0).scope()
$(selector) 和 $$(selector): 可以方便的替代 querySelector() 和 querySelectorAll。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询