带有Knockout绑定的完美滚动条

时间:2014-05-13 16:18:03

标签: javascript jquery knockout.js perfect-scrollbar

任何人都可以帮助我完成滚动条jquery的敲除绑定处理程序

这是viewmodel

var ViewModel = function () {
this.JobItems = ko.observableArray([
    {
        JobStatus : "New",
        Registration : "123",
        LicencePlate : "234",
        DeliveryDate : "08/01/2014",
        AdditionalInformation : "aasdfa"
    },
    {
        JobStatus : "In Progress",
        Registration : "234",
        LicencePlate : "456",
        DeliveryDate : "04/07/2014",
        AdditionalInformation : "aasdfa"
    },
    {
        JobStatus : "Closed",
        Registration : "abc",
        LicencePlate : "xyz",
        DeliveryDate : "08/01/2014",
        AdditionalInformation : "aasdfa"
    }
]);}

这是代码

<div class="jobListContent" id="create-task-animate-trigger" data-bind="foreach: JobItems, perfectScrollbar: { }">
    <div class="jobListContentItems" data-bind="click: jobListContentItemsClick, css: isActive">
        <div class="status">
            <span data-bind="if: JobStatus() == 'New'">
            <!--<img src="" alt="New Job" />-->
            </span>
            <span data-bind="if: JobStatus() == 'In Progress'">
                <img src="images/jobcards/progress_status.png" alt="In Progress" />
            </span>
            <span data-bind="if: JobStatus() == 'Completed'">
                <img src="images/jobcards/completed.png" alt="Completed" />
            </span>
            <span data-bind="if: JobStatus() == 'Closed'">
                <img src="images/jobcards/closed.png" alt="Closed" />
            </span>
        </div>
        <div class="registration" data-bind="text: Registration"></div>
        <div class="licence" data-bind="text: LicencePlate"></div>
        <div class="delivery" data-bind="text: DeliveryDate"></div>
        <div class="information" data-bind="text: AdditionalInformation"></div>
    </div>
</div>

这是敲除绑定处理程序,它显示鼠标悬停但不能正常工作的滚动条

ko.bindingHandlers.perfectScrollbar = {
    init: function (element, valueAccessor, allBindingsAccessor) {

        var options = valueAccessor() || {};
        $(element).perfectScrollbar(options);

        ko.utils.domNodeDisposal.addDisposeCallback(element, function () {
            $(element).perfectScrollbar("destroy");
        });
    },
    update: function(element, valueAccessor, allBindingsAccessor) {

        $(element).perfectScrollbar('update');
    }
};

1 个答案:

答案 0 :(得分:4)

尝试在init中注册事件处理程序:

init: function (element, valueAccessor, allBindingsAccessor) {
    ...trimmed...

    //handle the mouse over event, change to fit
    ko.utils.registerEventHandler(element, "mouseenter", function () {
      $(element).perfectScrollbar('update');
    });