本文摘自PHP中文网,作者青灯夜游,侵删。
本篇文章给大家介绍一下Angular中elem.scope()、elem.isolateScope和$compile(elem)(scope)中scope的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。【相关推荐:《angular教程》】
在angular的使用过程中我们经常用$rootScope.$new()为elem创建一个新的作用域scope,然后使用$compile(elem)(scope)编译这个含有指令的元素。那么这里传进去的scope到底是哪里的作用域?scope.$$childHead是什么作用域?编译好的elem.scope()返回的又是什么作用域?elem.isolateScope()返回的是什么作用域?知道这些是很有必要的,特别是使用jasmine测试angular指令的时候。下面使用一个例子来验证一下。
index.html
1 2 3 4 5 6 7 8 9 10 11 12 |
|
index.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
|
执行后的结果是,界面显示了红色的“你好吗?”,当然这不是我们所关注的。下面我们来看一下打印的日志:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
由此我们可以得出以下结论:
$compile(elem)(scope),这里的scope是指令的外围作用域。
elem.scope()返回的scope是指令的外围作用域。
elem.isolateScope()返回的才是指令的独立作用域。
scope.$$childHead返回的也是指令的独立作用域。
更多编程相关知识,请访问:编程教学!!
以上就是浅谈Angular中elem.scope()、elem.isolateScope和$compile(elem)(scope)中scope的区别的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
了解Angular中的变化检测(change detection)机制
更多相关阅读请进入《Angular》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者