Angular 作用域scope的具体使用


Posted in Javascript onDecember 11, 2017

Scope(作用域) 是应用在 HTML (视图) 和 JavaScript (控制器)之间的纽带。

Scope 是一个对象,有可用的方法和属性。

Scope 可应用在视图和控制器上。

$rootScope

每个AngularJs应用默认有一个根作用域--$rootScope, 根作用域位于最顶层,作为其他作用域的父作用域,可作用于整个应用中。

$scope

scope(作用域)对应MVC模式的Model,是应用在HTML(视图)和JavaScript(控制器)之间的纽带,可应用在视图和控制器上。

scope是表达式执行的上下文,同时作用域也是一个对象,有可用的方法和属性。

一、变量的取值和赋值

<div ng-controller="parentCtrl">
 <span>{{number}}</span>
 <div ng-controller="childCtrl">
  <span>{{number}}</span>
  <button ng-click="number = number +1">增加</button>
 </div>
</div>

function parentCtrl($scope){
 $scope.number = 1;
}
function childCtrl($scope){ 
}

效果:

界面上显示了两个1,但当我们点击按钮之后,childCtrl作用域内的数据改变了,parentCtrl作用域内的数据没有改变

分析:

①childCtrl作用域继承了parentCtrl作用域(类似于JavaScript的原型链继承),所以childCtrl作用域可以访问到parentCtrl的内容。
②点击按钮后childCtrl作用域就会创建一个number基础类型变量,当childCtrl已有某个基础类型变量就不会访问原型链。

解决:

①可以使用$parent来指定上级作用域改变

<div ng-controller="parentCtrl">
  <span>{{number}}</span>
  <div ng-controller="childCtrl">
   <span>{{number}}</span>
   <button ng-click="$parent.number = number +1">增加</button>
  </div>
 </div>

②使用引用类型变量,内外层作用域均是data对象的引用,修改对象的属性,引用的还是同一个变量。

<div ng-controller="parentCtrl">
  <span>{{data.number}}</span>
  <div ng-controller="childCtrl">
   <span>{{data.number}}</span>
   <button ng-click="data.number = data.number +1">增加</button>
  </div>
 </div>
 
 function parentCtrl($scope){
  $scope.data.number = 123';
 }
 function childCtrl($scope){
  
 }

ng-if、ng-repeat、ng-switch、ng-include等指令也会产生新作用域

二、Directive中的作用域

.directive("myDirective", function () {
return {
 restrict: "AE",
 scope: {
  name: '@myName',
  age: '=',
  changeAge: '&changeMyAge'
 },
 replace: true,
 template: "<div class='my-directive'>" +
  "我的名字是:<span ng-bind='name'></span><br/>" +
  "我的年龄是:<span ng-bind='age'></span><br/>" +
  "在这里修改名字:<input type='text' ng-model='name'><br/>" +
  "<button ng-click='changeAge()'>修改年龄</button>" +
  " </div>"
}

①scope:false

当scope设置为false的时候,我们创建的指令和父作用域(其实是同一个作用域)共享同一个model模型,所以在指令中修改模型数据,它会反映到父作用域的模型中。

②scope:true

当scope设置为true的时候,我们就新创建了一个作用域,只不过这个作用域是继承的父作用域;可以这样理解,我们新创建的作用域是一个新的作用域,只不过在初始化的时候,用了父作用域的属性和方法去填充我们这个新的作用域。它和父作用域不是同一个作用域。

③scope:{}

@ 这是一个单项绑定的前缀标识符

<div my-directive my-name="{{name}}"></div>

属性的名字要用-将两个单词连接,因为是数据的单项绑定所以要通过使用{{}}来绑定数据。

= 这是一个双向数据绑定前缀标识符

<div my-directive age="age"></div>

数据的双向绑定要通过=前缀标识符实现,所以不可以使用{{}}。

& 这是一个绑定函数方法的前缀标识符

<div my-directive change-my-age="changeAge()"></div>

属性的名字要用-将多个个单词连接。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 图片预览效果 推荐
Dec 22 Javascript
js中判断Object、Array、Function等引用类型对象是否相等
Aug 29 Javascript
table行随鼠标移动变色示例
May 07 Javascript
Position属性之relative用法
Dec 14 Javascript
easyui form validate总是返回false的原因及解决方法
Nov 07 Javascript
完美解决jQuery 鼠标快速滑过后,会执行多次滑出的问题
Dec 08 Javascript
深入理解JavaScript中的尾调用(Tail Call)
Feb 07 Javascript
解决Vue页面固定滚动位置的处理办法
Jul 13 Javascript
JavaScript 用fetch 实现异步下载文件功能
Jul 21 Javascript
使用async、enterproxy控制并发数量的方法详解
Jan 02 Javascript
webpack 静态资源集中输出的方法示例
Nov 09 Javascript
浅谈layui分页控件field参数接收对象的问题
Sep 20 Javascript
angularjs实现柱状图动态加载的示例
Dec 11 #Javascript
Vue响应式原理深入解析及注意事项
Dec 11 #Javascript
js时间戳与日期格式之间转换详解
Dec 11 #Javascript
js时间戳与日期格式之间相互转换
Dec 11 #Javascript
vue.js默认路由不加载linkActiveClass问题的解决方法
Dec 11 #Javascript
基于JavaScript 性能优化技巧心得(分享)
Dec 11 #Javascript
JavaScript时间戳与时间日期间相互转换
Dec 11 #Javascript
You might like
PHP递归实现汉诺塔问题的方法示例
2017/11/25 PHP
laravel 获取某个查询的查询SQL语句方法
2019/10/12 PHP
javascript 操作cookies及正确使用cookies的属性
2009/10/15 Javascript
JQuery 插件模板 制作jquery插件的朋友可以参考下
2010/03/17 Javascript
js绑定事件this指向发生改变的问题解决方法
2013/04/23 Javascript
jQuery实现动画效果的实例代码
2013/05/07 Javascript
JS父页面与子页面相互传值方法
2014/03/05 Javascript
nodejs中操作mysql数据库示例
2014/12/20 NodeJs
生成二维码方法汇总
2014/12/26 Javascript
javascript实现的字符串与十六进制表示字符串相互转换方法
2015/07/17 Javascript
jquery获取复选框的值的简单实例
2016/05/26 Javascript
AngularJS入门教程之服务(Service)
2016/07/27 Javascript
JS简单实现tab切换效果的多窗口显示功能
2016/09/07 Javascript
jQuery给指定的table动态添加删除行的操作方法
2016/10/12 Javascript
JavaScript的new date等日期函数在safari中遇到的坑
2016/10/24 Javascript
javascript简单进制转换实现方法
2016/11/24 Javascript
浅析JavaScript中break、continue和return的区别
2016/11/30 Javascript
jQuery监听浏览器窗口大小的变化实例
2017/02/07 Javascript
jQuery中的deferred对象和extend方法详解
2017/05/08 jQuery
JS动态添加的div点击跳转到另一页面实现代码
2017/09/30 Javascript
十分钟带你快速了解React16新特性
2017/11/10 Javascript
windows如何把已安装的nodejs高版本降级为低版本(图文教程)
2020/12/14 NodeJs
python解决字典中的值是列表问题的方法
2013/03/04 Python
python使用marshal模块序列化实例
2014/09/25 Python
Python自动化开发学习之三级菜单制作
2017/07/14 Python
聊聊python在linux下与windows下导入模块的区别说明
2021/03/03 Python
纯html5+css3下拉导航菜单实现代码
2013/03/18 HTML / CSS
俄罗斯卫浴采暖及维修用品超级市场:Dkrussia
2020/05/12 全球购物
音乐教学随笔感言
2014/02/19 职场文书
求职意向书
2014/07/29 职场文书
三严三实民主生活会发言稿
2014/10/13 职场文书
民主评议党员个人总结
2015/02/13 职场文书
2016春节放假通知范文
2015/08/18 职场文书
FP-growth算法发现频繁项集——构建FP树
2021/06/24 Python
python接口测试返回数据为字典取值方式
2022/02/12 Python
Python数据结构之队列详解
2022/03/21 Python