微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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/

原文地址:https://www.jb51.cc/jquery/176182.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐