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 开发中规范性的一点感想
Jun 23 Javascript
jQuery 创建Dom元素
May 07 Javascript
jQuery的初始化与对象构建之浅析
Apr 12 Javascript
jquery Mobile入门—外部链接切换示例代码
Jan 08 Javascript
jQuery验证插件validation使用指南
Apr 21 Javascript
Bootstrap面板(Panels)的简单实现代码
Mar 17 Javascript
jQuery实现的页面弹幕效果【测试可用】
Aug 17 jQuery
iview同时验证多个表单问题总结
Sep 29 Javascript
Node.js原生api搭建web服务器的方法步骤
Feb 15 Javascript
layui点击数据表格添加或删除一行的例子
Sep 12 Javascript
小程序实现录音上传功能
Nov 22 Javascript
浅谈React中组件逻辑复用的那些事儿
May 21 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中的日期加减方法示例
2014/08/21 PHP
[原创]php逐行读取txt文件写入数组的方法
2015/07/02 PHP
JS 文件大小判断的实现代码
2010/04/07 Javascript
jquery select(列表)的操作(取值/赋值)
2011/03/16 Javascript
jquery异步请求实例代码
2011/06/21 Javascript
JS获取页面input控件中所有text控件并追加样式属性
2013/02/25 Javascript
jQuery实现类似滑动门切换效果的层切换
2013/09/23 Javascript
JavaScript模拟重力状态下抛物运动的方法
2015/03/03 Javascript
Javascript中的arguments与重载介绍
2015/03/15 Javascript
通过js获取上传的图片信息(临时保存路径,名称,大小)然后通过ajax传递给后端的方法
2015/10/01 Javascript
jquery Deferred 快速解决异步回调的问题
2016/04/05 Javascript
完美解决IE9浏览器出现的对象未定义问题
2016/09/29 Javascript
详解nodejs中的process进程
2017/03/19 NodeJs
JS实现的走迷宫小游戏完整实例
2017/07/19 Javascript
JavaScript取得gridview中获取checkbox选中的值
2017/07/24 Javascript
详解Vue 动态组件与全局事件绑定总结
2018/11/11 Javascript
element-ui tree结构实现增删改自定义功能代码
2020/08/31 Javascript
JS实现公告上线滚动效果
2021/01/10 Javascript
浅谈插入排序算法在Python程序中的实现及简单改进
2016/05/04 Python
Queue 实现生产者消费者模型(实例讲解)
2017/11/13 Python
详谈Numpy中数组重塑、合并与拆分方法
2018/04/17 Python
python数据批量写入ScrolledText的优化方法
2018/10/11 Python
python 字符串常用函数详解
2019/09/11 Python
Python检查图片是否损坏及图片类型是否正确过程详解
2019/09/30 Python
python创建n行m列数组示例
2019/12/02 Python
Python使用requests模块爬取百度翻译
2020/08/25 Python
P D PAOLA意大利官网:西班牙著名的珠宝首饰品牌
2019/09/24 全球购物
大专自我鉴定范文
2013/10/23 职场文书
大专毕业自我鉴定
2014/02/04 职场文书
公交公司毕业生求职信
2014/02/15 职场文书
幼儿园大班开学教师寄语
2014/04/03 职场文书
个人合作协议书范本
2014/04/18 职场文书
优秀学生干部事迹材料
2014/12/24 职场文书
如何制作自己的原生JavaScript路由
2021/05/05 Javascript
MongoDB使用场景总结
2022/02/24 MongoDB
为自由献出你的心脏!「进击的巨人展 FINAL」2022年6月在台开展
2022/04/13 日漫