kogrid与服务器端分页+过滤:self.sortedData不是一个函数

时间:2013-01-29 16:30:38

标签: javascript knockout.js kogrid

我遇到了淘汰赛和kogrid的问题。经过几次测试,我设法在这个小提琴中重现它:

http://jsfiddle.net/MVuUp/

简而言之,我有一个示例VM( ItemsViewModel ),它应该向kogrid提供数据,并使用服务器实现的过滤和分页。 vm公开了一个 gridOptions 对象,其中包含kogrid所需的所有数据,以及一个刷新函数,用于从服务器获取数据。在小提琴中,我替换了ajax调用以获取具有一些虚拟内联数据的实际数据。

现在,在加载页面时,我经常在kogrid源中出现此错误:

  

错误:TypeError:self.sortedData不是函数源文件:   http://ericmbarnard.github.com/KoGrid/lib/KoGrid.debug.js行:1473

如果相反,我只使用名为dummyData的可观察数组,只有网格的div,就像基本的kogrid样本(https://github.com/Knockout-Contrib/KoGrid)一样,这个错误不会出现;所以我想我的库使用有问题。

以下是我的VM的相关部分:

function ItemsViewModel() {
    var self = this;
    self.dummyArray = ko.observableArray([{
        name: "Goofy",
        age: 27
    }, {
        name: "Mickey",
        age: 33
    }]);
    self.items = ko.observableArray([]);
    self.filterOptions = {
        filterText: ko.observable(""),
        useExternalFilter: true
    };
    self.pagingOptions = {
        pageSizes: ko.observableArray([5, 10]),
        pageSize: ko.observable(20),
        totalServerItems: ko.observable(0),
        currentPage: ko.observable(1)
    };
    self.gridOptions = {
        data: self.items,
        enablePaging: true,
        multiSelect: false,
        filterOptions: self.filterOptions,
        pagingOptions: self.pagingOptions,
        columnDefs: [{
            field: "id",
            displayName: "ID"
        }, {
            field: "title",
            displayName: "Title"
        }]
    };
    self.refresh();
}

此函数用于获取数据(目前我已经过滤掉了):

ItemsViewModel.prototype.refresh = function () {
var params = {
    page: this.pagingOptions.currentPage(),
    pageSize: this.pagingOptions.pageSize(),
    sortBy: "datemodified",
    isSortDesc: true
};
// dummy data (2 pages x 5)
var data = {
    page: 1,
    totalPages: 2,
    totalRecords: 10,
    records: []
};
for (var i = 0; i < 10; i++) {
    data.records.push({
        id: i,
        title: "title " + i
    });
}
ko.utils.arrayPushAll(this.items, data.records);
this.pagingOptions.totalServerItems(data.totalRecords);
}

我的HTML只是一个数据绑定设置为

的div
koGrid: { data: gridOptions }

1 个答案:

答案 0 :(得分:3)

在你的html中,更改

<div class="datagrid" data-bind="koGrid: { data: gridOptions }"></div>

<div class="datagrid" data-bind="koGrid: gridOptions "></div>