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 相关文章推荐
基于jQuery图片平滑连续滚动插件
Apr 27 Javascript
完美兼容各大浏览器的jQuery仿新浪图文淡入淡出间歇滚动特效
Nov 12 Javascript
hovertree插件实现二级树形菜单(简单实用)
Dec 28 Javascript
jquery网页加载进度条的实现
Jun 01 jQuery
AngularJS 实现点击按钮获取验证码功能实例代码
Jul 13 Javascript
vuex的简单使用教程
Feb 02 Javascript
详解基于Koa2开发微信二维码扫码支付相关流程
May 16 Javascript
Vue项目中跨域问题解决方案
Jun 05 Javascript
微信小程序如何使用canvas二维码保存至手机相册
Jul 15 Javascript
VUEX采坑之路之获取不到$store的解决方法
Nov 08 Javascript
js实现随机圆与矩形功能
Oct 29 Javascript
nestjs中异常过滤器Exceptionfilter的具体使用
Feb 07 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
ThinkPHP单字母函数(快捷方法)使用总结
2014/07/23 PHP
PHP中overload与override的区别
2017/02/13 PHP
JavaScript Event学习补遗 addEventSimple
2010/02/11 Javascript
制作高质量的JQuery Plugin 插件的方法
2010/04/20 Javascript
『JavaScript』限制Input只能输入数字实现思路及代码
2013/04/22 Javascript
js浮动图片的动态效果
2013/07/10 Javascript
js操作iframe兼容各种主流浏览器示例代码
2013/07/22 Javascript
javascript去除字符串中所有标点符号和提取纯文本的正则
2014/06/07 Javascript
Angular中$compile源码分析
2016/01/28 Javascript
Angular中使用ui router实现系统权限控制及开发遇到问题
2016/09/23 Javascript
最好用的Bootstrap fileinput.js文件上传组件
2016/12/12 Javascript
canvas学习之API整理笔记(二)
2016/12/29 Javascript
JS验证全角与半角及相互转化的介绍
2017/05/18 Javascript
JS滚动到指定位置导航栏固定顶部
2017/07/03 Javascript
jQuery实现倒计时功能 jQuery实现计时器功能
2017/09/19 jQuery
bootstrap模态框关闭后清除模态框的数据方法
2018/08/10 Javascript
解决echarts数据二次渲染不成功的问题
2020/07/20 Javascript
vue离开当前页面触发的函数代码
2020/09/01 Javascript
vue项目页面嵌入代码块vue-prism-editor的实现
2020/10/30 Javascript
微信小程序自定义tabBar的踩坑实践记录
2020/11/06 Javascript
[07:01]DOTA2-DPC中国联赛正赛 Aster vs Magma 3月5日 赛后选手采访
2021/03/11 DOTA
python中偏函数partial用法实例分析
2015/07/08 Python
python xml.etree.ElementTree遍历xml所有节点实例详解
2016/12/04 Python
python监控进程脚本
2018/04/12 Python
PyQt5显示GIF图片的方法
2019/06/17 Python
python3注册全局热键的实现
2020/03/22 Python
基于python实现数组格式参数加密计算
2020/04/21 Python
Python列表如何更新值
2020/05/27 Python
深入理解css中vertical-align属性
2017/04/18 HTML / CSS
HTML5头部标签的一些常用信息小结
2016/10/23 HTML / CSS
大学生实习自我鉴定
2013/12/11 职场文书
企业委托书范本
2014/09/13 职场文书
2015年清明节活动总结
2015/02/09 职场文书
致接力运动员加油稿
2015/07/21 职场文书
css样式important规则的正确使用方式
2022/06/10 HTML / CSS
使用 DataAnt 监控 Apache APISIX的原理解析
2022/07/07 Servers