当我们构建AngularJS应用时,通过浏览器(如Chrome,Firefox和IE)的JavaScript控制台访问应用中隐藏的数据和服务总会有些困难。下面是一些简单的技巧可以帮助我们通过Javascript控制台来查看或者控制正在运行的Angular应用,使得应用可以比较容易进行测试,修改,甚至实时的修改我们的Angular应用:
1: 访问作用域

通过一行简单的JS程序访问页面中任何作用域(甚至是隔离的作用域!):
> angular.element(targetNode).scope()
-> ChildScope {$id: "005", this: ChildScope, $$listeners: Object, $$listenerCount: Object, $parent: Scope…}
对于隔离作用域:
> angular.element(targetNode).isolateScope()
-> Scope {$id: "009", $$childTail: ChildScope, $$childHead: ChildScope, $$prevSibling: ChildScope, $$nextSibling: Scope…}
这里用`targetNode`作为HTML节点的引用。你可以非常轻松的通过`document.querySelector()`来创建一个`targetNode`
2:查看作用域树
有些时候,我们需要查看页面中作用域层次来有效的调试我们的应用。AngularJS Batarang正是我们需要的一款Chrome浏览器的扩展,可以展示当前作用域层次,并具有其他非常有用的特性。
3: 抓取任何服务
无论ngApp在哪里定义,我们都可以使用注入器功能来抓取任何的服务的引用(如果使用angular的bootstrap方法,则可以手动抓取$rootElement):
> angular.element('html').injector().get('MyService')
-> Object {undo: function, redo: function, _pushAction: function, newDocument: function, init: function…}
然后我们就可以对该服务进行调用,就像我们可以将服务注入一样。
4: 访问控制器使用指令
一些指令定义了一个拥有某些额外(通常是分享)功能的控制器。为了从控制台访问一个给定指令的控制器实例,只需使用 controller() 方法:
> angular.element('my-pages').controller()
-> Constructor {}
最后一种做法更高级并且不常用。
5: Chrome 控制台特性
Chrome浏览器的控制台有一堆不错的捷径 来调试浏览器应用。这是一些Angular开发中最好的做法:
- $0-$4: 访问最近在查看窗口中进行选取的 5 个DOM元素。选择抓取的范围非常方便。
- $(selector)和$$(selector): 分别是querySelector() 和 querySelectorAll的一个快速的替代
感谢 @zgohr 提供这种方法!
结论
通过几个简单的技巧,我们可以访问页面任何作用域中的数据,查看作用域层次结构,注入服务和控制指令。
所以下一次,如果你想稍微进行调整,检查自己的工作或者通过控制台控制AngularJS一个用,我希望你能记住这些命令,并且能做到像我一样觉得他们非常实用!
相关推荐:
用AI写文章,释放你的创作潜力!
优化入口:提升网站流量与转化率的秘密武器,琼海关键词排名品牌
“更加通顺”-让生活与工作无缝衔接的语言魅力,SEO书架书桌收纳
文章AI生成软件高效创作新纪元
什么是SEO金融,seo是做什么的 ,ai中转程序
ChatGPT:打破语言障碍,理解与沟通的新时代,交通轨道ai
seo要学什么语言,做seo需要什么语言 ,ai martino
SEO发明:引领数字时代营销革命的力量,速卖通外贸推广网站
ChatGPT破解:人工智能未来的无限可能,污污AI解说
SEO抢权:如何在竞争激烈的市场中占得先机,正规网站建设口碑好
AI自动帮写,轻松应对内容创作挑战,赋能写作新未来,嘿科技ai
seo词库优化,搜索词条优化 ,ai点选择
SEO大神如何在激烈的互联网竞争中脱颖而出?,网页设计和网站建设试题
seo监控什么意思,seo数据监控 ,ai panda眼镜架
SEO做网站点击:提升网站流量的关键策略,国内ai写作论文
seo算是什么营销方式,seo是网络营销吗 ,ai318
ChatGPT已识别但不可用?揭秘背后原因与解决方案!,小狸ai和斑马ai语文
SEO项目:如何通过精确优化提升企业网站排名与转化率,武汉做网站优化的公司
AI撰写大数据解决方案:开启智能数据时代的新篇章,ai头号公敌
AI免费试用不需要登录:体验智能科技的魅力,轻松开启未来,华为ai身材
ChatGPT在处理文本时可能无法完全理解上下文的复杂性,肌肉ai
seo组建需要什么条件,seo建站的步骤 ,ai肌肉宝宝
SEO查看-如何通过精确分析提升网站流量与排名,东丽网站建设价格
seo要会些什么,seo需要学些什么内容 ,轻盈ai
好用的人工智能AI软件推荐,让你的生活更智能!
SEO单页网站:助力企业在线营销的一站式解决方案,湖南视频网站优化方式
SEO优化是做什么的?让你的网站流量飙升的秘密武器,乳腺癌ai作用机理
ChatGPT破解版:让人工智能助力你的工作与生活,ai cos帽
ChatGPT一经发布,便受到了用户的狂热追捧,引爆人工智能热潮,十代ai达人办公本
seo矩阵运营中心是什么,seo矩阵运营中心是什么意思啊 ,北京ai特效
OpenAIGPT:开启智能时代的语言革命,ai辣妹动漫
ChatGPTWindows版本下载:让AI助力您的工作和生活,ai yamama
SEO快速优化技术:助力网站流量暴增,轻松登顶搜索引擎,铜陵ai全网通推广软件
AI的两个主要发展阶段:从起步到突破,如何重塑未来,wps ai写作去哪里
优化工具:提升工作效率的秘密武器,网站模板的优化策略是什么
seo网站排名优化哪家好,seo网站优化平台 ,ai斗蟋
SEO任何:如何通过精准优化让网站流量突破极限,太原网站建设培训班
seo软件叫什么,seo软件视频教程 ,eps ai 缩略图
SEO永远,数字营销的核心力量,广州seo搜索栏内容
SEO优化基础:让你的网站脱颖而出的秘密武器,模仿猫ai
优化*:打造更加高效、创新的娱乐体验,石排网站建设制作多少钱
智能AI写文章:高效创作新风尚
SEO运维:提升网站排名的核心战略,邢台网站建设优化建站
SEO优化的利器:提升网站排名的秘密武器,联想ai7g-3笔记本
ChatGPT破解:让AI打破语言与思维的边界,ai模板vis
SEO与SEM策略:提升网站流量与品牌曝光的双剑合璧,ai补图
AI人工智能:开发与应用的必备软件推荐
什么是seo网络推广seo顾问,seo网络推广员 ,ai20170119
SEO优化:提升网站流量的终极指南,揭阳网站快速推广
SEO优化:让你的网站在竞争中脱颖而出,临沧seo代理