Angular.Js之Scope作用域的学习教程
scope是什么?
大家都知道在AngularJS中作用域是一个指向应用模型的对象,它是表达式的执行环境。作用域有层次结构,这个层次和相应的DOM几乎是一样的。作用域能监控表达式和传递事件。
在HTML代码中,一旦一个ng-app指令被定义,那么一个作用域就产生了,由ng-app所生成的作用域比较特殊,它是一个根作用域($rootScope),它是其他所有$Scope的最顶层。
除了用ng-app指令可以产生一个作用域之外,其他的指令如ng-controller,ng-repeat等都会产生一个或者多个作用域。此外,还可以通过AngularJS提供的创建作用域的工厂方法来创建一个作用域。这些作用域都拥有自己的继承上下文,并且根作用域都为$rootScope。
在生成一个作用域之后,在编写AngularJS代码时,$scope对象就代表了这个作用域的数据实体,我们可以在$scope内定义各种数据类型,之后可以直接在HTML中以{{变量名}}方式来让HTML访问到这个变量。
继承作用域
AngularJS在创建一个作用域时,会检索上下文,如果上下文中已经存在一个作用域,那么这个新创建的作用域就会以JavaScript原型继承机制继承其父作用域的属性和方法。
一些AngularJS指令会创建新的子作用域,并且进行原型继承:ng-repeat、ng-include、ng-switch、ng-view、ng-controller,用scope:true和transclude:true创建的directive。
以下HTML中定义了三个作用域,分别是由ng-app指令所创建的$rootScope,parentCtrl和childCtrl所创建的子作用域,这其中childCtrl生成的作用域又是parentCtrl的子作用域。
示例一:作用域的继承实例
scopenick angular.module('app',[]) .controller('parentCtrl',['$scope',function($scope){ $scope.args='NickDeveloperWorks'; }]) .controller('childCtrl',['$scope',function($scope){ $scope.args='NickDeveloperWorksfortest'; }]);