【发布时间】:2014-01-08 11:36:56
【问题描述】:
使用 angular.js 给出以下代码
请戳这里:http://plnkr.co/edit/i4MAzs
HTML:
<form name="myForm" ng-controller="Ctrl">
Try clicking on the labels. <br/>
<label>
Value1: <input type="checkbox" ng-checked='value1' ng-click='toggleValue1()'>
</label> <br/>
<label ng-click='toggleValue2()'>
Value2: <input type="checkbox" ng-checked="value2">
</label> <br/>
<tt>value1 = {{value1}}</tt><br/>
<tt>value2 = {{value2}}</tt><br/>
<tt>fire_count = {{fire_count}}</tt>
</form>
Javascript:
angular.module('App', []);
function Ctrl($scope) {
$scope.value1 = true;
$scope.value2 = 'YES'
$scope.fire_count = 0;
$scope.toggleValue1 = function(){
$scope.value1 = !$scope.value1;
$scope.fire_count++;
console.log("Clicked!");
}
$scope.toggleValue2 = function(){
$scope.value2 = !$scope.value2;
$scope.fire_count++;
console.log("Clicked!");
}
}
单击“Value2”标签时,单击事件将触发两次。这仅在 ng-click 附加到标签时发生。当它附加到输入元素时,一切都按预期工作。
有人可以解释发生了什么吗?
【问题讨论】:
-
很奇怪,如果你把“label”改成“div”就可以正常工作了
标签: javascript angularjs