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 在光标定位的地方插入文字的插件
May 10 Javascript
jQuery使用append在html元素后同时添加多项内容的方法
Mar 26 Javascript
基于jQuery+Cookie实现的防止刷新的在线考试倒计时
Jun 19 Javascript
利用jQuery实现漂亮的圆形进度条倒计时插件
Sep 30 Javascript
javascript实现html页面之间参数传递的四种方法实例分析
Dec 15 Javascript
jQuery Timelinr实现垂直水平时间轴插件(附源码下载)
Feb 16 Javascript
PassWord输入框代码分享
Jun 07 Javascript
微信小程序 实战程序简易新闻的制作
Jan 09 Javascript
原生JS仿QQ阅读点击展开、收起效果
Mar 08 Javascript
jquery.pagination.js分页使用教程
Oct 23 jQuery
JavaScript动态添加数据到表单并提交的几种方式
Jun 26 Javascript
使用Vant完成通知栏Notify的提示操作
Nov 11 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+mysql删除指定编号员工信息的方法
2015/01/14 PHP
为百度UE编辑器上传图片添加水印功能
2015/04/16 PHP
php集成套件服务器xampp安装使用教程(适合第一次玩PHP的新手)
2015/06/03 PHP
PHP正则验证Email的方法
2015/06/15 PHP
详解WordPress中添加友情链接的方法
2016/05/21 PHP
header与缓冲区之间的深层次分析
2016/07/30 PHP
PHP学习记录之数组函数
2018/06/01 PHP
PHP设计模式之装饰器(装饰者)模式(Decorator)入门与应用详解
2019/12/13 PHP
javascript+css 网页每次加载不同样式的实现方法
2009/12/27 Javascript
javascript工厂方式定义对象
2014/12/26 Javascript
EasyUi datagrid 实现表格分页
2015/02/10 Javascript
JavaScript搜索字符串并将搜索结果返回到字符串的方法
2015/04/06 Javascript
在JavaScript的jQuery库中操作AJAX的方法讲解
2015/08/15 Javascript
跟我学习javascript的最新标准ES6
2015/11/20 Javascript
浅谈JavaScript的push(),pop(),concat()方法
2016/06/03 Javascript
正则表达式(语法篇推荐)
2016/06/24 Javascript
Javascript实现代码折叠功能
2016/08/25 Javascript
jquery实现的table排序功能示例
2017/03/10 Javascript
浅谈Node 调试工具入门教程
2018/03/20 Javascript
vue 中基于html5 drag drap的拖放效果案例分析
2018/11/01 Javascript
Element-ui自定义table表头、修改列标题样式、添加tooltip、:render-header使用
2019/04/11 Javascript
js canvas实现5张图片合成一张图片
2019/07/15 Javascript
TypeScript中使用getElementXXX()的示例代码
2019/09/12 Javascript
javascript实现下拉菜单效果
2021/02/09 Javascript
Python中用format函数格式化字符串的用法
2015/04/08 Python
python结合selenium获取XX省交通违章数据的实现思路及代码
2016/06/26 Python
Python实现1-9数组形成的结果为100的所有运算式的示例
2017/11/03 Python
Python使用googletrans报错的解决方法
2018/09/25 Python
YSL圣罗兰美妆美国官网:Yves Saint Lauret US
2016/11/21 全球购物
伦敦剧院门票:London Theatre Direct
2018/11/21 全球购物
广告学专业推荐信范文
2013/11/23 职场文书
人事部经理岗位职责
2014/03/07 职场文书
2014年电话销售工作总结
2014/12/01 职场文书
幼儿园开学通知
2015/04/24 职场文书
比赛口号霸气押韵
2015/12/24 职场文书
Python实现位图分割的效果
2021/11/20 Python