jQueryUI Spinner小部件与淘汰赛

前端之家收集整理的这篇文章主要介绍了jQueryUI Spinner小部件与淘汰赛前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如何在Knockout绑定输入中使用 jQuery UI Spinner小部件?
<tbody data-bind="foreach: orders">
        <tr>
            <td data-bind="text: Name"></td>
            <td><input type="number" style="width: 100px;" data-bind="value: Price" /></td>
            <td><input type="number" style="width: 50px;" data-bind="value: VAT" /></td>
            <td><input type="number" style="width: 50px;" data-bind="value: Number" /></td>
            <td data-bind="text: Final()"></td>
            <td><a href="javascript:void(0);" data-bind="click: $root.removeOrder">Remove</a></td>
        </tr>    
    </tbody>

解决方法

最好的方法是创建自定义绑定以将微调框绑定到输入:
ko.bindingHandlers.spinner = {
    init: function(element,valueAccessor,allBindingsAccessor) {
        //initialize spinner with some optional options
        var options = allBindingsAccessor().spinnerOptions || {};
        $(element).spinner(options);

        //handle the field changing
        ko.utils.registerEventHandler(element,"spinchange",function () {
            var observable = valueAccessor();
            observable($(element).spinner("value"));
        });

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

    },update: function(element,valueAccessor) {
        var value = ko.utils.unwrapObservable(valueAccessor()),current = $(element).spinner("value");

        if (value !== current) {
            $(element).spinner("value",value);
        }
    }
};

然后只是使用它而不是值绑定:

<input
    type="number"
    style="width: 100px;"
    data-bind="spinner: Price,spinnerOptions: { min: 0 } " />

这里是工作小提琴:http://jsfiddle.net/vyshniakov/SwKGb/

猜你在找的jQuery相关文章