我有一个绑定到许多复选框的Kendo可观察对象。当我通过单击复选框来更新复选框时,可观察对象将正确更新。但是,如果我通过代码更新选中的状态,则不会更新可观察对象。
下面是一个示例片段,我有一个Kendo UI Dojo。单击红色、绿色或蓝色复选框时,框中会显示正确的信息;但是,如果使用"全选"选项,则不会更新可观察对象。
如何正确编写"全选"复选框的代码,以便可观察对象随选中状态一起更新?
$(document).ready(function () {
var colordata = null;
colordata = kendo.observable({
colors: []
});
kendo.bind($("#chkbox-options"), colordata);
colordata.bind("change", function(e) {
var selectedColors = '';
$.each(colordata.colors, function(key, value){
selectedColors = selectedColors + " " + value;
});
if(colordata.colors.length == 0){
$("#selected").val('no colors selected');
}else{
$("#selected").val('selected colors:' + selectedColors);
}
});
$("#all").on("click", function() {
$("#chkbox-options input[type='checkbox']").prop("checked", $(this).prop("checked"));
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script src="http://cdn.kendostatic.com/2015.1.318/js/kendo.all.min.js"></script>
<input id="all" type="checkbox" />
<label for="all">Select All</label>
<div class="k-group" id="chkbox-options">
<label for="chk1">Red</label>
<input type="checkbox" id="chk1" value="Red" data-bind="checked: colors" />
<label for="chk2">Green</label>
<input type="checkbox" id="chk2" value="Green" data-bind="checked: colors" />
<label for="chk3">Blue</label>
<input type="checkbox" id="chk3" value="Blue" data-bind="checked: colors" />
</div>
<input id="selected" style="width:100%;" />
您的错误是您正在使用属性更改,jquery prop方法没有触发colordata更改事件,jquery API解释道:
对于选择框、复选框和单选按钮,当用户用鼠标进行选择时,事件会立即触发,但对于其他元素类型,事件会推迟到元素失去焦点
因此,您应该使用click()
方法,而不是使用prop()
。固定道场1
在使用prop()
之后,您可以使用trigger("change")
的另一种方法。固定dojo 2