jQuery UI datepicker change event not caught by KnockoutJS

后端 未结 13 2402
长发绾君心
长发绾君心 2020-11-22 16:16

I\'m trying to use KnockoutJS with jQuery UI. I have an input element with a datepicker attached. I\'m currently running knockout.debug.1.2.1.js and it seems th

13条回答
  •  谎友^
    谎友^ (楼主)
    2020-11-22 16:17

    Same as RP Niemeyer, but better support of WCF DateTime, Timezones and Using the DatePicker onSelect JQuery property.

            ko.bindingHandlers.datepicker = {
            init: function (element, valueAccessor, allBindingsAccessor) {
                //initialize datepicker with some optional options
                var options = allBindingsAccessor().datepickerOptions || {};
    
                var funcOnSelectdate = function () {
                    var observable = valueAccessor();
                    var d = $(element).datepicker("getDate");
                    var timeInTicks = d.getTime() + (-1 * (d.getTimezoneOffset() * 60 * 1000));
    
                    observable("/Date(" + timeInTicks + ")/");
                }
                options.onSelect = funcOnSelectdate;
    
                $(element).datepicker(options);
    
                //handle the field changing
                ko.utils.registerEventHandler(element, "change", funcOnSelectdate);
    
                //handle disposal (if KO removes by the template binding)
                ko.utils.domNodeDisposal.addDisposeCallback(element, function () {
                    $(element).datepicker("destroy");
                });
    
            },
            update: function (element, valueAccessor) {
                var value = ko.utils.unwrapObservable(valueAccessor());
    
                //handle date data coming via json from Microsoft
                if (String(value).indexOf('/Date(') == 0) {
                    value = new Date(parseInt(value.replace(/\/Date\((.*?)\)\//gi, "$1")));
                }
    
                current = $(element).datepicker("getDate");
    
                if (value - current !== 0) {
                    $(element).datepicker("setDate", value);
                }
            }
        };
    

    Enjoy :)

    http://jsfiddle.net/yechezkelbr/nUdYH/

提交回复
热议问题