5

我最近一直在玩 Angular.js,并决定在选中父复选框后检查所有复选框,我已经使用ng-modelng-checked指令完成了。

    <div ng-app>
        <div ng-controller="Ctrl">
            <input type="checkbox" ng-model="parent"/> Select All<br/>
            <input type="checkbox" ng-model="child_1" ng-checked="parent" ng-click="getAllSelected()"/> First<br/>
            <input type="checkbox" ng-model="child_2" ng-checked="parent" ng-click="getAllSelected()"/> Second<br/>
            <input type="checkbox" ng-model="child_3" ng-checked="parent" ng-click="getAllSelected()"/> Three<br/>
            <input type="checkbox" ng-model="child_4" ng-checked="parent" ng-click="getAllSelected()"/> Four<br/>
            <input type="checkbox" ng-model="child_5" ng-checked="parent" ng-click="getAllSelected()"/> Five<br/>
        </div>
    </div>

现在,一旦选中了所有子复选框,我就会尝试选择所有父复选框,但会遇到一些问题。

    function Ctrl($scope) {
       $scope.getAllSelected = function () {
          var chkChild = document.querySelectorAll('input[ng-model^="child_"]').length;
          var chkChildChecked = document.querySelectorAll('input[ng-model^="child_"]:checked').length;
          if (chkChild === chkChildChecked) $scope.parent= true;
          else $scope.parent= false;
       }
    }

演示:http: //jsfiddle.net/codef0rmer/QekpX/

我们能让上面的代码更健壮吗?

4

2 回答 2

6

复选框中的 ng-checked 属性接受一个表达式。因此,您可以给出一个带有和/或条件的表达式,如下所述,以使其基于表达式进行检查。

<input type="checkbox" ng-checked="child_1 && child_2 && child_3 && child_4 && child_5" ng-model="parent"/> Select All<br/>

单击每个子复选框时,您不必编写单独的函数来进行计算。

这是jsfiddle中的示例

于 2012-08-27T15:13:08.813 回答
0

从视觉上看,它会更新使用 ng-selected 选中的所有复选框,但是当您实际提交数据时,数据与所选内容不匹配。我建议做一个 ng-click() 这很糟糕,但如果你的数据是动态的。

http://codepen.io/stirlingw/pen/gpwXWM

//Random JSON object
$scope.labels = 
  [{
    label: 'Death Row Records', 
    selected: false, 
    artists: [
      {artist: 'MC Hammer', selected: false},
      {artist: 'Andre "Dr. Dre" Young', selected: false},
      {artist: 'Snoop Dogg', selected: false},
      {artist: 'Tupac Shakur', selected: false},
      {artist: 'Nate Dogg', selected: false},
   ]
}]; 

//JS
$scope.clicker = function(label){
  label.artists.forEach(function(e){
    e.selected = !label.selected;
  });
};

//html
<ul>
   <li ng-repeat="label in labels"> <input type="checkbox" ng-model="label.selected" ng-click="clicker(label)"> {{label.label}} 
       <ul>
           <li ng-repeat="artist in label.artists">
               <input type="checkbox" ng-model="artist.selected" > {{artist.artist}}
           </li>
       </ul> 
   </li>  
</ul>
于 2015-05-21T20:32:46.437 回答