Knockout create array in viewmodel

只谈情不闲聊 提交于 2019-12-13 03:51:23

问题


another knockout question.

I've a page where serversided paging is desirable. I wanna achieve this using knockout.

I Create a viewmodel using the mapping pluging and added lots of functionality.

        var jsonModel = '@Html.Raw(Newtonsoft.Json.JsonConvert.SerializeObject(this.Model, new Newtonsoft.Json.Converters.IsoDateTimeConverter()))';
        myViewModel = ko.mapping.fromJSON(jsonModel, {}, new ViewModel());
        ko.applyBindings(myViewModel);

I've implemented a computed observable at first. But this gave an error because the 'requestData' isn't initialized. therefore the updated variant with an 'if (typeof self.requestData != 'undefined')'

function ViewModel() {
var self = this;
//---- Return PageNumbers
self.Paging = ko.computed(function () {
    if (typeof self.requestData != 'undefined') {
        if (self.requestData.settings.pageNumber() <= 5) {
            return ko.utils.range(1, 11);
        }
        if (self.requestData.settings.pageNumber() + 5 > self.requestData.settings.nbrOfPages()) {
            return ko.utils.range(self.requestData.settings.nbrOfPages() - 11, self.requestData.settings.nbrOfPages());
        }
        return ko.utils.range(self.requestData.settings.pageNumber() - 5, self.requestData.settings.pageNumber() + 5);
    };
    return ko.utils.range(1, 11);
});

the array should be updated when i make a call to the ajaxrequest:

self.changePage = function(pageNumber) {
    self.Paging = ko.utils.range(pageNumber -1 > 0 ?)
    myViewModel.requestData.settings.pageNumber = pageNumber;
    $.ajax({
        type: "post",
        contentType: "application/json",
        url: "../Refund/FilterPageSortingChange",
        data: ko.toJSON(self.requestData),
        error: function (xhr, status, error) {
            baseShowError("Server Error", "Error changing page");
        },
        success: function (response) {
            var receivedResponse = JSON.parse(response);
            if (receivedResponse.Success) {
                ko.mapping.fromJS(receivedResponse.Result, {}, self);
            } else {
                baseShowError("Page not found", receivedResponse.message);
            }
        }
    });
};

What should i do for updating the paging array on receiving new data?

Kinds regards

UPDATE: Apart from my code, whats the best/easiest option to create an observable array thats depandant of the pageNumber?


回答1:


Your pageNumber is an observable, but when you assign it like this:

myViewModel.requestData.settings.pageNumber = pageNumber;

you have erased the observable and replace it with a simple value. You should assign it like this:

myViewModel.requestData.settings.pageNumber(pageNumber);


来源:https://stackoverflow.com/questions/20982614/knockout-create-array-in-viewmodel

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!