angularjs指令中scope参数 true、false、{} 的区别详解
scope 有三个参数 true、false、{}
scope 默认是 false,当 scope设置为true时,会从父作用域继承并创建一个新的作用域对象,
按照true 、false的反向思维,我就理解为scope不设置,或者设置为false的时候,就不从父作用域继承(理解错误主要就是因为这句话)。
这里的不从父作用域继承可以分为两种情况
1、创建一个新的作用域对象,但不继承父作用域 (创建、不继承)
2、压根就不创建新的作用域对象,直接跟父作用域共享一个作用域,也就谈不到继承了。 (不创建、直接用、谈何继承)
弄清楚这个我就明白了,scope:false 和scope:true的本质区别是创不创建新的作用域对象,而不是继不继承的问题。
放几个例子,代码不多,直接写在一个里面了:
指令中的templateUrl共用一个模板:scopeTemplate.html
<p>我的名字是:{{ name }}</p> <!-- 常量 -->
<p>我的年龄是:{{ age }}</p> <!-- 变量 -->
<p><button ng-click="greeting()">称呼</button></p> <!-- 方法 -->
<input type="text" ng-model="name" />
<br /><br />
scope:false (跟父作用域共享一个作用域的时候)
<!DOCTYPE html>
<html ng-app="myapp">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="../js/angular.min.js" ></script>
</head>
<body>
<div ng-controller="myController">
<p>我的名字是:{{ name }}</p> <!-- 常量 -->
<p>我的年龄是:{{ age }}</p> <!-- 变量 -->
<p><button ng-click="greeting()">称呼</button></p> <!-- 方法 -->
<input type="text" ng-model="name" />
<br /><br />
<p>指令1 scope=false:</p>
<div my-directive></div>
</div>
</body> <script type="text/javascript">
var app = angular.module('myapp',[]);
app.controller('myController',['$scope',function($scope){
$scope.name = "wanglehui";
$scope.age = 23;
$scope.greeting = function(){
alert('我叫'+$scope.name);
}
}]) /* 指令2 scope==false */
app.directive('myDirective',[function(){
return{
restrict:'AE',
scope:false,
templateUrl:'scopeTemplate.html'
}
}])
</script>
</html>
测试的时候注意angularjs的版本问题。
这个很容易理解,两个同时改变,因为用的是同一个作用域,用的是同一个变量。
scope:true (从父作用域继承并创建一个新的作用域对象)
<!DOCTYPE html>
<html ng-app="myapp">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="../js/angular.min.js" ></script>
</head>
<body>
<div ng-controller="myController">
<p>我的名字是:{{ name }}</p> <!-- 常量 -->
<p>我的年龄是:{{ age }}</p> <!-- 变量 -->
<p><button ng-click="greeting()">称呼</button></p> <!-- 方法 -->
<input type="text" ng-model="name" />
<br /><br />
<p>指令1 scope=true:</p>
<div my-directive></div>
</div>
</body> <script type="text/javascript">
var app = angular.module('myapp',[]);
app.controller('myController',['$scope',function($scope){
$scope.name = "wanglehui";
$scope.age = 23;
$scope.greeting = function(){
alert('我叫'+$scope.name);
}
}]) /* 指令2 scope==true */
app.directive('myDirective',[function(){
return{
restrict:'AE',
scope:true,
templateUrl:'scopeTemplate.html'
}
}])
</script>
</html>
这块有一点需要注意下,
刷新——>输入第一个,第二个会跟着变——>输入第二个,第一个不变——>再输入第一个,第二个也不变了(之后两个互不影响)
刷新——>输入第二个,第一个不变——>输入第一个,第二个不变(之后两个互不影响)
也就是说,如果我们不在第二个输入框输入,也就不会在指令新建的作用域对象中创建新的变量,它每次显示的就是在父作用域中查询到的值
一旦输入,就已经在该对象下新建了一个变量。(这块跟js变量作用域的查找是一样的)
再看第三个 scope:{}
书上说这块叫隔离作用域,隔离.....也就是我是一个新的个体,跟外界没关系
前面说 scope:false 和scope:true的 本质区别是创不创建新的作用域对象,而不是继不继承的问题。
那么这里scope:{}和scope:true的 本质区别是继不继承父作用域的问题,而不是创不创建新的作用域对象的问题。
scope:{} (创建一个新的作用域对象,但不继承父作用域)
<!DOCTYPE html>
<html ng-app="myapp">
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript" src="../js/angular.min.js" ></script>
</head>
<body>
<div ng-controller="myController">
<p>我的名字是:{{ name }}</p> <!-- 常量 -->
<p>我的年龄是:{{ age }}</p> <!-- 变量 -->
<p><button ng-click="greeting()">称呼</button></p> <!-- 方法 -->
<input type="text" ng-model="name" />
<br /><br />
<p>指令 scope={}:</p>
<div my-directive></div>
</div>
</body> <script type="text/javascript">
var app = angular.module('myapp',[]);
app.controller('myController',['$scope',function($scope){
$scope.name = "wanglehui";
$scope.age = 23;
$scope.greeting = function(){
alert('我叫'+$scope.name);
}
}]) /* 指令2 scope==true */
app.directive('myDirective',[function(){
return{
restrict:'AE',
scope:{},
templateUrl:'scopeTemplate.html'
}
}])
</script>
</html>
如果想要scope{}中的变量与父作用域绑定, 就会用到angularjs中的绑定策略“@”,“=”,“&”
angularjs指令中scope参数 true、false、{} 的区别详解的更多相关文章
- JS中escape()、encodeURI()、encodeURIComponent()区别详解
avaScript中有三个可以对字符串编码的函数,分别是: escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decode ...
- AngularJS 指令中的 replace:true
默认值是fasle,模板会被当作子元素插入到调用此指令的元素内部. <my-directive></my-directive> myModule.directive(" ...
- Batch批处理中的 参数 路径和字符串 处理详解
1.截取字符串 截取字符串可以说是字符串处理功能中最常用的一个子功能了,能够实现截取字符串中的特定位置的一个或多个字符.举例说明其基本功能: @echo off set ifo=abcdefghijk ...
- 【转】 深入main函数中的参数argc,argv的使用详解
C/C++语言中的main函数,经常带有参数argc,argv,如下: 复制代码 代码如下: int main(int argc, char** argv) 这两个参数的作用是什么呢?argc 是指命 ...
- JQuery中$.each 和$(selector).each()的区别详解
PS:晚上在写页面时,发现了一个问题,$.each 和$(selector).each()有哪些区别?百度搜索关键词,首页显示出来一些前人的经验,总结一下,发上来. 1.$(selector).eac ...
- php中const与define的使用区别 详解
1.const用于类成员变量定义,一旦定义且不能改变其值.define定义全局常量,在任何地方都可以访问. 2.define不能在类中定义而const可以. 3.const不能在条件语句中定义常量 i ...
- jsp中的@include与jsp:include区别详解
1 前言 搞java开发的人也许都知道在jsp中引入项目中其他文件有如下两种方式 <%@include file="xxx.jsp"%> <jsp:include ...
- java中==和equals和hashcode的区别详解
一.相同点 都是用来进行值或对象的比较. 二.不同点 对于“==”而言,对于基本类型(char,byte,short,int,long,float,double,boolean),对比的是值,所以是相 ...
- css中postion的fixed与absolute区别详解
fixed:固定定位,参照位置是浏览器窗口的左上角,即坐标点为(0px, 0px) absolute:绝对定位,参展位置是离当前元素最近的定位方式为fixed,absolute,relative的祖先 ...
随机推荐
- mouseover与mouseenter,mouseout与mouseleave的区别
mouseover事件:不论鼠标指针穿过被选元素或其子元素,都会触发 mouseover 事件,对应mouseout事件: mouseenter事件:只有在鼠标指针穿过被选元素时,才会触发 mouse ...
- centos mpeg acc 解码器安装
# yum -y install http://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-5.el7.nux.noar ...
- MyBatis:一对一关联查询
MyBatis从入门到放弃三:一对一关联查询 前言 简单来说在mybatis.xml中实现关联查询实在是有些麻烦,正是因为起框架本质是实现orm的半自动化. 那么mybatis实现一对一的关联查询则是 ...
- python 模块之-hashlib
python 模块hashlib import hashlib m=hashlib.md5() # 生成MD5加密对象 m.update('jiami-string'.encode(' ...
- BZOJ3832[Poi2014]Rally——权值线段树+拓扑排序
题目描述 An annual bicycle rally will soon begin in Byteburg. The bikers of Byteburg are natural long di ...
- Ubuntu 安装 hadoop
安装完Linux后,我们继续(VMWare 安装 Linux http://blog.csdn.net/hanjun0612/article/details/55095955) 这里我们开始学习安装 ...
- Sightseeing tour HDU - 1956(混合欧拉回路)
题意: 有n个点,m条边,其中有单向边和双向边,求是否存在欧拉回路 解析: 刚开始想...判断一下每个点的度数不就好了...emm..还是年轻啊.. 判断是解决不了问题的,因为可能会有某两个点冲突,比 ...
- MT【222】几道自招面试真题
1.(2015东南大学)2分钟找杯子,4分钟找茶叶,7分钟烧水,爸爸花13分钟给家访的老师泡茶,请问你怎么看? 2.(2014复旦大学)共有5顶帽子,三个黑的两个白的,三个人排成一排,并让这三个人每个 ...
- DP的各种优化(动态规划,决策单调性,斜率优化,带权二分,单调栈,单调队列)
前缀和优化 当DP过程中需要反复从一个求和式转移的话,可以先把它预处理一下.运算一般都要满足可减性. 比较naive就不展开了. 题目 [Todo]洛谷P2513 [HAOI2009]逆序对数列 [D ...
- IScroll的那些事——内容不足时下拉刷新
之前项目中的列表是采用的IScroll,但是在使用IScroll有一个问题就是:当内容不足全屏的时候,是木有办法往下拉的,这样就达不到刷新的目的了.[这是本人工作中遇到的,具体例子具体分析,这里只作一 ...