与其他指令一样,ng-if指令也会创建一个子级作用域,因此,如果在ng-if指令中添加了元素,并向元素属性增加 ng-model指令, 那么ng-model指令对应的作用域属性子级作用域,而并非控制器注入的$scope作用域对象,这点在进行双向数据绑定时,需要引起注意。 在ng-if方式中,每个包含的元素都拥有自己的作用域,因此,复选框元素也拥有自己的$scope作用域。相对于控制器作用域来说,这个作用域属于一个子级作用域,所以,如果它想绑定控制器中的变量值,必须添加$parent标识,只有这样才能访问到控制器中的变量。
因此,解决ng-if中ng-model值无效的问题,主要方法就是在绑定值时添加$parent标识,或者用ng-show指令代替ng-if指令,这两种方法都可以达到同样的页面效果。
http://blog.csdn.net/u013451157/article/details/60866210
第一个ngif---{
{obj.xx}} { {x.num}}第二个ngif--{
{obj.xx}}选中的数字:{
{obj.xx}} js部分
var app = angular.module('app1', []); app.controller('c1', function ($scope) { $scope.a=true; $scope.b=true; $scope.arry=[ { 'id':'liu', num:965 },{ 'id':'luke', num:562 },{ 'id':'jack', num:326 } ]; //这里本来只需要定义一个 $scope.obj={}的对象其实就可以了, 我这里是让单选框默认选择最后一个单选框为选中状态所以就将ng-model中的xx赋值为json数组最后num中的数字值了 $scope.obj={ xx:$scope.arry[$scope.arry.length-1].num }; $scope.showtime=function(){ console.log("输出数字:"+$scope.obj.xx); } });
上面三个obj.xx值虽然在不同的ngif下他们的值也是一样绑定了 截图效果: 1.开始默认最后一个单选框选中 2.再次点击其他单选框,他们的值就绑定了
2
笔记做完了!有问题或者其他方法,望各位大神指点!