首页 > 编程 > JavaScript > 正文

Angular.js之作用域scope'@','=','&'实例详解

2019-11-19 17:23:07
字体:
来源:转载
供稿:网友

什么是scope

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

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

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

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

下面通过实例代码给大家介绍angular.js之作用域scope'@','=','&'

<!doctype html> <html ng-app='myApp'> <head> </head> <body>   <script src="http://cdn.bootcss.com/angular.js/1.4.6/angular.js"></script>  <script src="https://cdn.bootcss.com/jquery/1.8.3/jquery.js"></script>  <div ng-controller="listCtrl" ng-app="myApp">     <input type="text" ng-model="color">     <!-- <span kid hd-color="color"></span> --> <!--@是单项数据绑定,hd-color="{{color}}"作用域隔离,在view中是以模板“{{}}”的形式;=双向绑定,hd-color="color",在view中直接以属性的形式出现-->    <div kid color="callback()"></div>  </div><script type="text/javascript">    var myApp=angular.module('myApp',[]);     myApp.controller('listCtrl',function($scope){       $scope.color="red";       $scope.callback=function(){        return 'a web developer !';      }    });     myApp.directive('kid',function(){       return {         restrict:'AE',         //template:'<div style="color:{{color}}">@符号的学习</div>' ,         template:'<h1>{{color()}}</h1>',         scope:{ /*color:"=hdColor"*//* "@hdColor" */color:'&'} //通过&属性名来调用控制器的函数      }     }); </script></div> </body></html>

以上所述是小编给大家介绍的Angular.js之作用域scope'@','=','&'实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对武林网网站的支持!

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表