剑道可观察复选框未通过 jQuery 更新 .prop( "checked" )



我有一个绑定到许多复选框的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

相关内容

  • 没有找到相关文章

最新更新