我正在使用prettyCheckable jquery插件使我的复选框和单选按钮看起来很漂亮,如果我使用data-bind =“checked:dateMode”则不起作用,因为该插件隐藏了实际的复选框并使其自身覆盖html成为漂亮复选框/收音机,因此当我检查收音机或复选框并更新模型中的值时,knockoutjs库无法识别。我知道如果不使用prettyCheckable插件,我的代码就可以正常工作,所以不要告诉我我的模型或数据绑定(bind)代码搞砸了。我测试了这个。

https://github.com/arthurgouveia/prettyCheckable

这是我的部分 View 代码。

<div id="DatesChooser" class="span5 pull-left">
    <h4><i class="icon-calendar"></i>Dates</h4>
    <input type="radio" name="Date" value="All" data-label="All Available" data-bind="checked: dateMode" /><br />
    <input type="radio" name="Date" value="Range" data-label="Range" data-bind="checked: dateMode" />
    <div data-bind="visible: dateMode() == 'Range'">
        <input type="text" id="FromYear" placeholder="1970" /> to
        <input type="text" id="ToYear" placeholder="2012" /><br />
        <div id="Date-Slider" class="ui-slider ui-slider-horizontal ui-widget ui-widget-content ui-corner-all">
            <div id="Date-Slider-Bar" class="ui-slider-range ui-widget-header" style="left: 0%; width: 100%;"></div>
            <a class="ui-slider-handle ui-state-default ui-corner-all" href="#" style="left: 0%;"></a>
            <a class="ui-slider-handle ui-state-default ui-corner-all" href="#" style="left: 100%;"></a>
        </div>
    </div>
</div>

这是我的 knockout 模型:
function searchVm() {
    var self = this;
    self.dateMode = ko.observable("All");
    self.startSearch = function () { alert(self.dateMode()); };
};

我初始化了prettyCheckable这样的东西:
$('input:checkbox').prettyCheckable();
$('input:radio').prettyCheckable();

这是在prettyCheckable插件对其进行修改后呈现的代码,请注意输入样式是'display:none':
<div id="DatesChooser" class="span5 pull-left">
    <div class="clearfix prettyradio labelright blue">
        <input type="radio" data-bind="checked: dateMode" data-label="All Available" value="All" name="Date" style="display: none;" checked="checked">
        <a class="checked" href="#"></a>
        <label for="undefined">All Available</label>
    </div>
    <br>
    <div class="clearfix prettyradio labelright blue">
        <input type="radio" data-bind="checked: dateMode" data-label="Range" value="Range" name="Date" style="display: none;">
        <a class="" href="#"></a>
        <label for="undefined">Range</label>
    </div>
    <div data-bind="visible: dateMode() == 'Range'" style="display: none;">
        <input id="FromYear" class="placeholder" type="text" placeholder="1970">
to
        <input id="ToYear" class="placeholder" type="text" placeholder="2012">
        <br>
        <div id="Date-Slider" class="ui-slider ui-slider-horizontal ui-widget ui-widget-content ui-corner-all">
            <div id="Date-Slider-Bar" class="ui-slider-range ui-widget-header" style="left: 0%; width: 100%;"></div>
            <a class="ui-slider-handle ui-state-default ui-corner-all" style="left: 0%;" href="#"></a>
            <a class="ui-slider-handle ui-state-default ui-corner-all" style="left: 100%;" href="#"></a>
            <div class="ui-slider-range ui-widget-header" style="left: 0%; width: 100%;"></div>
        </div>
    </div>
 </div>

最佳答案

Pretty Checkable会在复选框上触发change事件,但Knockout会查找click事件。这可以通过更改prettyCheckable.js行46-54来解决。原版的:

    if (input.attr('checked') !== undefined) {
      input.removeAttr('checked').change();
    } else {
      input.attr('checked', 'checked').change();
    }

已更改:
    if (window.ko) {
      ko.utils.triggerEvent(input[0], 'click');
    } else {
      input.click();
    }

如果您使用jQuery的click触发函数,则 knockout 也将无效。您必须如上所述使用Knockout的triggerEvent

jsFiddle:http://jsfiddle.net/mbest/4cX48/

关于javascript - 使用带有击倒js 2.1检查数据绑定(bind)的prettyCheckable插件不起作用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14148901/

10-11 09:16