javascript - 选择的自定义绑定(bind)无法将对象作为值处理

标签 javascript knockout.js jquery-select2 knockout-3.0

我有一个设置,其中我使用基于 observableArray 的选项填充一个选择。该数组包含具有更多属性的对象,而不仅仅是一个 id 和一个名称。我希望能够使用完整的 javascript 对象作为选定值。

数据是这样的:

this.optionData = ko.observableArray([
    {id: 1, name: "One", param: true},
    {id: 2, name: "Two", param: true},
    {id: 3, name: "Three", param: true},
]);

在 knockout 中使用标准绑定(bind)非常简单

<select data-bind="
   options: optionData,
   optionsText: 'name',
   optionsCaption: 'Please select',
   value: selectedOption">
</select>

但是,我想为我的选择设置样式,并为它们添加更多功能。我为此使用 select2。我提出了以下自定义绑定(bind),这适用于同时使用 optionsText 和 optionsValue 的简单绑定(bind) - 但它不适用于没有 optionsValue 的选项绑定(bind)(即,当使用对象作为值时)。

ko.bindingHandlers.select2 = {
init: function (el, valueAccessor, allBindingsAccessor, viewModel) {

    ko.utils.domNodeDisposal.addDisposeCallback(el, function () {
        $(el).select2('destroy');
    });

    var allBindings = allBindingsAccessor(),
        select2 = ko.utils.unwrapObservable(valueAccessor());

    $(el).select2(select2);
},

update: function (element, valueAccessor, allBindingsAccessor, viewModel) {

    var selectedOptions = ko.unwrap(allBindingsAccessor.get("selectedOptions")),
        val = ko.unwrap(allBindingsAccessor.get("value")),
        options = ko.unwrap(allBindingsAccessor.get("options"));

    if ($(element).prop('multiple')) {
        $(element).select2('val', selectedOptions, true);
    }
    else {
        $(element).select2("val", val);
    }

    $(element).trigger('change');
}

};

我的问题是,我需要更新什么才能让我的自定义绑定(bind)作为默认的 knockout 选项绑定(bind)工作?

我制作了这个 fiddle 来演示这个问题:http://jsfiddle.net/SuneRadich/LdF45/1/

最佳答案

我的示例可能有助于使用 optionsAfterRender 获取对象。

<select id="selectArticles" multiple
 data-bind="options: availableArticles, selectedOptions: selectedArticles,
 optionsText: function(item){return item.title},
 optionsAfterRender: function(option, item){option.value = item}">
</select>

workding fiddle

如有必要,我可以将其更改为单选。

关于javascript - 选择的自定义绑定(bind)无法将对象作为值处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25143082/

相关文章:

javascript - 如何在运行 Node.js 的服务器上保存文件?

javascript - 如何在 React 中呈现 HTML 评论?

javascript - 使用 json 数据的 CanvasJs 图表

javascript - 使用 Knockout JS 和 Bootstrap 的多级菜单

javascript - Knockoutjs super 基础知识

twitter-bootstrap - 如何在 bootstrap 3 导航栏中使 select2 v4 搜索框响应?

javascript - 每次调用函数时都会晚1ms 调用它吗?

c# - 在 ASP .NET MVC 中,Knockout html 绑定(bind)不起作用(绑定(bind)到调用局部 View 的函数)

javascript - 选择 2 : cannot read property query of null

javascript - Vue.js select2 Wrapper 组件改变事件