AngularJS解决ng-if中的ng-model值无效的问题

叁歲伎倆 2022-04-03 04:42 253阅读 0赞

与其他指令一样, ng-if 指令也会创建一个子级作用域,因此,如果在 ng-if 指令中添加了元素,并向元素属性增加 ng-model 指令,那么 ng-model 指令对应的作用域属性子级作用域,而并非控制器注入的 $scope 作用域对象,这点在进行双向数据绑定时,需要引起注意, $parent 可以解决。

  1. <!DOCTYPE html>
  2. <html ng-app="myApp">
  3. <head>
  4. <meta charset="UTF-8">
  5. <script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
  6. <style>
  7. .frame{
  8. padding: 5px 8px;
  9. margin: 0px;
  10. font-size: 12px;
  11. width: 320px;
  12. background-color: #eee;
  13. }
  14. .frame div{
  15. margin: 5px 0px;
  16. }
  17. </style>
  18. </head>
  19. <body>
  20. <div ng-controller="myCtrl" class="frame">
  21. <div>
  22. a 的值: {
  23. {a}} <br>
  24. b 的值: {
  25. {b}}
  26. </div>
  27. <div>
  28. 普通方式: <input type="checkbox" ng-model="a">
  29. </div>
  30. <div ng-if="!a">
  31. ngIf方式:<input type="checkbox" ng-model="$parent.b">
  32. </div>
  33. </div>
  34. <script>
  35. angular.module('myApp', [])
  36. .controller('myCtrl', function($scope){
  37. $scope.a = false;
  38. $scope.b = false;
  39. })
  40. </script>
  41. </body>
  42. </html>

在 ng-if 方式中,每个包含的元素都拥有自己的作用域,因此,复选框元素也拥有自己的 $scope 作用域。相对于控制器作用域来说,这个作用域属于一个子级作用域,所以,如果它想绑定控制器中的变量值,必须添加 $parent 标识,只有这样才能访问到控制器中的变量。
因此,解决 ng-if 中 ng-model 值无效的问题,主要方法就是在绑定值时添加 $parent 标识,或者用 ng-show 指令代替 ng-if 指令,这两种方法都可以达到同样的页面效果。
转自https://blog.csdn.net/u013451157/article/details/60866210

发表评论

表情:
评论列表 (有 0 条评论,253人围观)

还没有评论,来说两句吧...

相关阅读