angularJs数据绑定失效的坑
2020-04-01 18:51
1081 查看
angularJS 数据绑定失效
摘要
相信大家在进行angularJs开发的时候也会遇到我现在遇到的问题:明明页面进行了双向数据绑定,而且数据已经改变了,但是视图却并未刷新。
代码示例
<div ng-controller="testCtrl"> <p>{{name}}</p> <div ng-if="show"> <input type="text" ng-model="name"> </div> </div> <script> function testCtrl($scope){ $scope.show = true; $scope.name = 'xiao ming'; } </script>
按照代码所展示的,我们在改变input的值时,变量name的值应该会因为数据的双向绑定而进行改变,与input的value保持一致。但是,实际上却没有发生视图上的变化。
原因就是因为ng-if会隔离作用域,创建新的作用域。使得scope.name压根与input里的name不是一个作用域上的值,自然无法做出更改。
作用域
每个 Angular 应用默认有一个根作用域 $rootScope, 根作用域位于最顶层,从它往下挂着各级作用域。
通常情况下,页面中 ng-model 绑定的变量都是在对应的 Controller 中定义的。如果一个变量未在当前作用域中定义,JavaScript 会通过当前 Controller 的 prototype 向上查找,也就是作用域的继承。
解决方案
<div ng-controller=“testCtrl"> <p>{{data.name}}</p> <div ng-if="show"> <input type="text" ng-model="data.name"> </div> </div> <script> function testCtrl($scope){ $scope.show = true; $scope.data = {}; $scope.data.name = 'xiao ming'; } </script>
ng-if其实是隔离出了一块作用域,此时testCtrl是父级作用域,ng-if相当于子级作用域,此时通过引用data便可实现双向数据绑定。
ng-if中的作用域
在这种情况下,两者的 data 是同一个引用,对这个对象上面的属性修改,是可以反映到两级对象上的。
实际情况是并不是只有 Controller 可以创建作用域,ng-if 等指令也会(隐式地)产生新作用域。总结下来就是,ng-if、 ng-switch 、 ng-include 等会动态创建一块界面的东西,都是自带一级作用域。因此,在开发过程中应尽可能的使用对象引用。
- 点赞
- 收藏
- 分享
- 文章举报
相关文章推荐
- 深入浅析AngularJS中的一次性数据绑定 (bindonce)
- 数据绑定-AngularJS第一课
- Angularjs绑定数据时对html标签的转义
- AngularJs——双向数据绑定示例
- AngularJS入门教程之数据绑定用法示例
- AngularJS笔记---数据绑定
- AngularJs 基础教程 (二) 数据的绑定与表达式
- AngularJs-数据绑定
- 谈谈AngularJS中的一次性数据绑定
- 双向数据绑定---AngularJS的基本原理学习
- angularJS双向数据绑定
- 再谈angularJS数据绑定机制及背后原理—angularJS常见问题总结
- angularjs的使用:$scope与双向数据绑定,自动注入(6)
- AngularJS 数据绑定
- AngularJS入门教程之数据绑定原理详解
- AngularJs轻松入门(二)数据绑定
- AngularJS 数据绑定
- DataBindings绑定数据控件失效
- 关于 AngularJS 的数据绑定
- ionic -- 单选框使用数据双向绑定(angularjs)问题