ngCheckedを使ってチェックボックスの連動をさせると、表示上はチェックが入るがngModelにはtrue/falseが反映されない。
反映元のngChangeを拾ってJavaScript側で書けば回避できるが、なんか釈然としない。(そもそもngCheckedはそういう風に使うもんではないのかもちれんが)
親しか変更が反映されない
<!DOCTYPE html>
<html lang="ja" ng-app="testApp">
<head>
<meta charset="utf-8">
<title>ngModelとngCheckedの動作チェック</title>
</head>
<body>
<div ng-controller="testCtrl">
<form novalidate>
<input type="checkbox" ng-model="checkbox.parent">親<br>
<input type="checkbox" ng-model="checkbox.child" ng-checked="checkbox.parent">子<br>
{{checkbox|json}}<br>
</form>
</div>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.6/angular.min.js"></script>
<script>
var testApp = angular.module('testApp', []);
testApp.controller('testCtrl', function ($scope) {
return false;
});
</script>
</body>
</html>
scriptを追記すれば反映される
var testApp = angular.module('testApp', []);
testApp.controller('testCtrl', function ($scope) {
$scope.setChildCheckbox = function(){
$scope.checkbox.child = $scope.checkbox.parent;
return false;
};
return false;
});