zoukankan      html  css  js  c++  java
  • ng-if 下ng-model失效 ng-repeat循环输出单选框

     与其他指令一样,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




    <p ng-if="a">
    第一个ngif---{{obj.xx}}
    <br/>
    <br/>
    <span ng-repeat="x in arry">
    <input type="radio" name="num" ng-value="x.num" ng-model="$parent.obj.xx" />{{x.num}}
    </span>
    </p>

    <p ng-if="b">
    第二个ngif--{{obj.xx}}
    </p>

    <p>选中的数字:{{obj.xx}}</p>

    <button ng-click="showtime()"> 输出数字</button>


    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

    笔记做完了!有问题或者其他方法,望各位大神指点!



  • 相关阅读:
    Shell 同时读取多个文件
    Shell 进度条效果的一个实现
    在 CentOS7 上安装 Tomcat9
    Redis原子计数器incr,防止并发请求
    .Net高并发解决思路
    Redis windows服务器配置可远程连接
    Lambda表达式和For循环使用需要注意的一个地方
    C#多线程和线程池
    MongoDb 物理位置应用实现
    Android Studio3.0 配置AndroidAnnotation注解框架
  • 原文地址:https://www.cnblogs.com/liucong7708/p/6481145.html
Copyright © 2011-2022 走看看