Angular.Js之范围作用域的学习教程

  

  

大家都知道在AngularJS中作用域是一个指向应用模型的对象,它是表达式的执行环境。作用域有层次结构,这个层次和相应的DOM几乎是一样的。作用域能监控表达式和传递事件。

  

在HTML代码中,一旦一个ng-app指令被定义,那么一个作用域就产生了,由ng-app所生成的作用域比较特殊,它是一个根作用域(rootScope美元),它是其他所有美元范围的最顶层。

  

除了用ng-app指令可以产生一个作用域之外,其他的指令如ng-controller, ng-repeat等都会产生一个或者多个作用域。此外,还可以通过AngularJS提供的创建作用域的工厂方法来创建一个作用域。这些作用域都拥有自己的继承上下文,并且根作用域都为rootScope美元。

  

在生成一个作用域之后,在编写AngularJS代码时,美元范围对象就代表了这个作用域的数据实体,我们可以在美元范围内定义各种数据类型,之后可以直接在HTML中以{{变量名}}方式来让HTML访问到这个变量。

  

  

AngularJS在创建一个作用域时,会检索上下文,如果上下文中已经存在一个作用域,那么这个新创建的作用域就会以JavaScript原型继承机制继承其父作用域的属性和方法。

  

一些AngularJS指令会创建新的子作用域,并且进行原型继承:ng-repeat, ng-include, ng-switch, ng-view, ng-controller,用<代码>范围:真正的和<代码> transclude:真正的创建的指令。

  

以下HTML中定义了三个作用域,分别是由ng-app指令所创建的rootScope美元,parentCtrl和childCtrl所创建的子作用域,这其中childCtrl生成的作用域又是parentCtrl的子作用域。

  

        & lt; !doctype html>   & lt; html>   & lt; head>   & lt;元charset=utf - 8”/比;   & lt; title> nick<范围;/title>   & lt;脚本src=" http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js "祝辞& lt;/script>   & lt;/head>   & lt;脚本type=" text/javascript祝辞   角。模块(“应用程序”,[])   范式(“parentCtrl”,[美元范围,函数(范围美元){   美元的范围。args=澳峥薉eveloperWorks”;   }))   范式(“childCtrl”,[美元范围,函数(范围美元){   美元的范围。args=澳峥薉eveloperWorks为测试”;   }));   & lt;/script>   & lt;身体ng-app=在“应用程序”;   & lt; div ng-controller=皃arentCtrl”比;   & lt;输入ng-model=安问北?   & lt; div ng-controller=癱hildCtrl”比;   & lt;输入ng-model=安问北?   & lt;/div>   & lt;/div>   & lt;/body>   & lt;/html>      

继承作用域符合JavaScript的原型继承机制,这意味着如果我们在子作用域中访问一个父作用域中定义的属性,JavaScript首先在子作用域中寻找该属性,没找到再从原型链上的父作用域中寻找,如果还没找到会再往上一级原型链的父作用域寻找。在AngularJS中,作用域原型链的顶端是rootScope美元,AnguarJS将会寻找到美元rootScope为止,如果还是找不到,则会返回定义。

  

我们用实例代码说明下这个机制。首先,我们探讨下对于原型数据类型的作用域继承机制:

  


  

        & lt; !doctype html>   & lt; html>   & lt; head>   & lt;元charset=utf - 8”/比;   & lt; title> nick<范围;/title>   & lt;脚本src=" http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js "祝辞& lt;/script>   & lt;/head>   & lt;脚本type=" text/javascript祝辞   角。模块(“应用程序”,[])   范式(“parentCtrl”,[美元范围,函数(范围美元){   美元的范围。args=澳峥薉eveloperWorks”;   }))   范式(“childCtrl”,[美元范围,函数(范围美元){   }));   & lt;/script>   & lt;身体ng-app=在“应用程序”;   & lt; div ng-controller=皃arentCtrl”比;   & lt;输入ng-model=安问北?   & lt; div ng-controller=癱hildCtrl”比;   & lt;输入ng-model=安问北?   & lt;/div>   & lt;/div>   & lt;/body>   & lt;/html>      

<强>测试运行结果:

  

第一个输入框:

  

虽然在childCtrl中没有定义具体的arg游戏属性,但是因为childCtrl的作用域继承自parentCtrl的作用域,因此,AngularJS会找到父作用域中的arg游戏属性并设置到输入框中。而且,如果我们在第一个输入框中改变内容,内容将会同步的反应到第二个输入框。

  

第二个输入框:

  

第二个输入框的内容从此将不再和第一个输入框的内容保持同步。在改变第二个输入框的内容时,因为HTML代码中模型明确绑定在childCtrl的作用域中,因此AngularJS会为childCtrl生成一个args原始类型属性。这样,根据AngularJS作用域继承原型机制,childCtrl在自己的作用域找得到args这个属性,从而也不再会去寻找parentCtrl的arg游戏属性。从此,两个输入框的内容所绑定的属性已经是两份不同的实例,因此不会再保持同步。

Angular.Js之范围作用域的学习教程