带有 Knockout.js 的 jQuery UI 日期选择器

标签 jquery jquery-ui knockout.js datepicker

我正在使用 knockout.js 来添加和删除表单中的字段。到目前为止它工作正常,但是我需要一个日期选择器选项,所以我使用了 jQuery 的 UI 日期选择器。这有效,但仅适用于第一个日期选择器,而不适用于其他任何地方。因此,每当我单击“添加”时,我都会得到新字段,但没有日期选择器。

我用谷歌搜索并搜索了StackExchange ,但没有找到复制字段的解决方案。

HTML

<table data-bind='visible: beschikkingen().length > 0'>
            <thead>
                <tr>
                    <th>Beschikkingsdatum</th>
                    <th>Beschikkingsnr</th>
                    <th />
                </tr>
            </thead>
            <tbody data-bind='foreach: beschikkingen'>
                <tr>
                    <td><input name="beschikkingsdatum[]" type="text" class="beschikkingsdatum" value="" data-bind='value: beschikkingsdatum, uniqueName: true' /> </td>
                    <td><input class='required number' data-bind='value: beschikkingsnummer, uniqueName: true' /></td>
                    <td><a href='#' data-bind='click: $root.removebeschikking'>Delete</a></td>
                </tr>
            </tbody>
        </table>

Knockout.JS

var beschikkingModel = function(beschikkingen) {
    var self = this;
    self.beschikkingen = ko.observableArray(beschikkingen);

    self.addbeschikking = function() {
        self.beschikkingen.push({
            beschikkingsdatum: "",
            beschikkingsnummer: ""
        });
    };

    self.removebeschikking = function(beschikking) {
        self.beschikkingen.remove(beschikking);
    };

    self.save = function(form) {
        alert("Could now transmit to server: " + ko.utils.stringifyJson(self.beschikkingen));
        // To actually transmit to server as a regular form post, write this: ko.utils.postJson($("form")[0], self.beschikkingen);
    };
};

var viewModel = new beschikkingModel([
    {
        beschikkingsdatum: "",
        beschikkingsnummer: ""
    }
]);
ko.applyBindings(viewModel);

// Activate jQuery Validation
$("form").validate({ submitHandler: viewModel.save });
//]]>  

日期选择器

$(window).load(function(){
$('.beschikkingsdatum').datepicker({
    dateFormat: 'dd-mm-yy',
    constrainInput: false
});
});

最佳答案

使用自定义绑定(bind)处理程序可以解决您的问题:

ko.bindingHandlers.datepicker = {
    init: function (element, valueAccessor, allBindingsAccessor) {
        var options = allBindingsAccessor().datepickerOptions || {};
        $(element).datepicker(options);

        //handle the field changing
        ko.utils.registerEventHandler(element, "change", function () {
            var observable = valueAccessor();
            observable($(element).datepicker("getDate"));
        });

        //handle disposal (if KO removes by the template binding)
        ko.utils.domNodeDisposal.addDisposeCallback(element, function () {
            $(element).datepicker("destroy");
        });
    }
};

在 HTML 中:

<input data-bind='datepicker: beschikkingsdatum' />

这是工作 fiddle :http://jsfiddle.net/QUxyy/

关于带有 Knockout.js 的 jQuery UI 日期选择器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13629910/

相关文章:

javascript - 仅在一个部分实现整页js效果

javascript - Typeahead.js 自动完成不显示任何建议

javascript - 在 JQueryUI 中,如果我在外部文件中构建和调用 javascript,则模式选项不起作用

javascript - 绑定(bind) Kendo Grid 与 Knockout : will config in javascript work with

angularjs - AngularJS 中 KnockoutJS 的 "with"绑定(bind)?

javascript - 将 24 小时格式转换为 12 小时格式

jquery - 将 JQuery Sortable toArray 与 connectWith 结合使用;如何获取所有元素的ID?

jQuery无冲突问题

javascript - 如何让 KnockOutJS 识别具有数据绑定(bind)属性的动态 html?

PHP session 不适用于 JQuery Ajax?