angularjs数据绑定失效的解决方法


本文摘自PHP中文网,作者青灯夜游,侵删。

相关推荐:《angularjs教程》

相信大家在进行angularjs开发的时候也会遇到我现在遇到的问题:明明页面进行了双向数据绑定,而且数据已经改变了,但是视图却并未刷新。

代码示例

1

2

3

4

5

6

7

8

9

10

11

12

<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 向上查找,也就是作用域的继承。

解决方案

1

2

3

4

5

6

7

8

9

10

11

12

13

<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数据绑定失效的解决方法的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

angularjs和vue.js有什么差异?简单对比

angularjs自定义一个可输入的下拉框组件(代码示例)

angular2 ngmodel模块的详细介绍

angularjs数据绑定失效的解决方法

angular与angularjs、react和vue的简单对比

angular和angularjs间有什么关系

谈谈angularjs中providers之间的差异

angularjs是什么?为什么用angularjs

eclipse中如何配置angularjs插件的方法

angularjs的ng-bind-html指令详解

更多相关阅读请进入《angularjs》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...