与其他指令一样,ng-if
指令也会创建一个子级作用域,因此,如果在ng-if
指令中添加了元素,并向元素属性增加 ng-model
指令,那么ng-model
指令对应的作用域属性子级作用域,而并非控制器注入的$scope
作用域对象,这点在进行双向数据绑定时,需要引起注意。
1 |
|
在ng-if
方式中,每个包含的元素都拥有自己的作用域,因此,复选框元素也拥有自己的$scope
作用域。相对于控制器作用域来说,这个作用域属于一个子级作用域,所以,如果它想绑定控制器中的变量值,必须添加$parent
标识,只有这样才能访问到控制器中的变量。
因此,解决ng-if
中ng-model
值无效的问题,主要方法就是在绑定值时添加$parent
标识,或者用ng-show
指令代替ng-if
指令,这两种方法都可以达到同样的页面效果。