时间:2021-05-25
当我们构建AngularJS应用时,通过浏览器(如Chrome,Firefox和IE)的JavaScript控制台访问应用中隐藏的数据和服务总会有些困难。下面是一些简单的技巧可以帮助我们通过Javascript控制台来查看或者控制正在运行的Angular应用,使得应用可以比较容易进行测试,修改,甚至实时的修改我们的Angular应用:
1: 访问作用域
通过一行简单的JS程序访问页面中任何作用域(甚至是隔离的作用域!):
对于隔离作用域:
这里用`targetNode`作为HTML节点的引用。你可以非常轻松的通过`document.querySelector()`来创建一个`targetNode`
2:查看作用域树
有些时候,我们需要查看页面中作用域层次来有效的调试我们的应用。AngularJS Batarang正是我们需要的一款Chrome浏览器的扩展,可以展示当前作用域层次,并具有其他非常有用的特性。
3: 抓取任何服务
无论ngApp在哪里定义,我们都可以使用注入器功能来抓取任何的服务的引用(如果使用angular的bootstrap方法,则可以手动抓取$rootElement):
然后我们就可以对该服务进行调用,就像我们可以将服务注入一样。
4: 访问控制器使用指令
一些指令定义了一个拥有某些额外(通常是分享)功能的控制器。为了从控制台访问一个给定指令的控制器实例,只需使用 controller() 方法:
最后一种做法更高级并且不常用。
5: Chrome 控制台特性
Chrome浏览器的控制台有一堆不错的捷径 来调试浏览器应用。这是一些Angular开发中最好的做法:
感谢 @zgohr 提供这种方法!
结论
通过几个简单的技巧,我们可以访问页面任何作用域中的数据,查看作用域层次结构,注入服务和控制指令。
所以下一次,如果你想稍微进行调整,检查自己的工作或者通过控制台控制AngularJS一个用,我希望你能记住这些命令,并且能做到像我一样觉得他们非常实用!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在使用GoogleChrome浏览器调试js时,会发现修改完js不会立即生效,这是由于chrome浏览器缓存的原因,而在火狐下没有这个问题。经常使用chrome
Chrome浏览器目前来看应该是大部分前端程序员都在使用它来开发调试。下面为大家列出了Chrome浏览器的快捷键。Windows和Linux版本的chrome标
自谷歌离开大陆以后,很多chrome内核的浏览器(包括360急速浏览器、火狐浏览器等)都无法使用内置翻译,此方法解决chrome浏览器翻译问题。1、用记事本打开
谷歌浏览器设置双击关闭网页方法如下: 1、在Chrome网上应用店,搜索pig,即可搜索到这个拓展程序; 2、安装后,重启一下chrome浏览器即可。
JavaScript程序越来越复杂,调试工具的重要性日益凸显。客户端脚本有浏览器,Node脚本怎么调试呢?2016年,Node决定将Chrome浏览器的"开发者