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 相关文章推荐
extjs 学习笔记 四 带分页的grid
Oct 20 Javascript
不同浏览器的怪癖小结
Jul 11 Javascript
javascript拓展DOM操作 prependChild insertAfert
Nov 17 Javascript
JQuery中层次选择器用法实例详解
May 18 Javascript
jQuery 遍历map()方法详解
Nov 04 Javascript
jQuery实现简单的手风琴效果
Apr 17 jQuery
vue增删改查的简单操作
Jul 15 Javascript
Vue.js实现网格列表布局转换方法
Aug 25 Javascript
详解vue-cli 快速搭建单页应用之遇到的问题及解决办法
Mar 01 Javascript
Webpack中publicPath路径问题详解
May 03 Javascript
vue.js 解决v-model让select默认选中不生效的问题
Jul 28 Javascript
threejs太阳光与阴影效果实例代码
Apr 05 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时间不正确的解决方法
2008/04/09 PHP
PHP执行zip与rar解压缩方法实现代码
2010/12/05 PHP
php empty() 检查一个变量是否为空
2011/11/10 PHP
php实现根据字符串生成对应数组的方法
2014/09/22 PHP
PHP实现简单的新闻发布系统实例
2015/07/28 PHP
WordPress中用于检索模版的相关PHP函数使用解析
2015/12/15 PHP
PHP的RSA加密解密方法以及开发接口使用
2018/02/11 PHP
PHP实现的大文件切割与合并功能示例
2018/04/10 PHP
TP5框架请求响应参数实例分析
2019/10/17 PHP
jquery ajax 同步异步的执行 return值不能取得的解决方案
2012/01/08 Javascript
jquery固定底网站底部菜单效果
2013/08/13 Javascript
jQuery绑定事件不执行但alert后可以正常执行
2014/06/03 Javascript
Javascript学习笔记之数组的遍历和 length 属性
2014/11/23 Javascript
JavaScript实现节点的删除与序号重建实例
2015/08/05 Javascript
详解JavaScript基本类型和引用类型
2015/12/09 Javascript
JavaScript自定义函数实现查找两个字符串最长公共子串的方法
2016/11/24 Javascript
xmlplus组件设计系列之图标(ICON)(1)
2017/05/05 Javascript
原生JS实现瀑布流插件
2018/02/06 Javascript
《Python学习手册》学习总结
2018/01/17 Python
python3 读写文件换行符的方法
2018/04/09 Python
浅谈关于Python3中venv虚拟环境
2018/08/01 Python
python实现栅栏加解密 支持密钥加密
2019/03/20 Python
Python+Dlib+Opencv实现人脸采集并表情判别功能的代码
2020/07/01 Python
DRF框架API版本管理实现方法解析
2020/08/21 Python
Html5 canvas画图白板踩坑
2020/06/01 HTML / CSS
Linux中如何设置Java环境变量(Ubuntu)
2016/07/24 面试题
校园门卫岗位职责
2013/12/09 职场文书
优秀毕业生求职信范文
2014/01/02 职场文书
2014年医学生毕业自我鉴定
2014/03/26 职场文书
亚运会口号
2014/06/20 职场文书
开展党的群众路线教育实践活动剖析材料
2014/10/13 职场文书
学生违纪检讨书200字
2014/10/21 职场文书
2015年专项整治工作总结
2015/04/03 职场文书
2016年党员公开承诺书范文
2016/03/24 职场文书
解决thinkphp6(tp6)在状态码500下不报错,或者显示错误“Malformed UTF-8 characters”的问题
2021/04/01 PHP
使用CSS实现黑白格背景效果
2022/06/01 HTML / CSS