淘汰映射;不起作用

Knockout Mapping doesn't work

本文关键字:不起作用 映射 淘汰      更新时间:2023-09-26

我在使用Knockout Mapping时遇到问题。

我有一个FormBuilderViewModel,它包含一系列函数,包括加载和保存数据。第一行(self-this之后)如下:

this.form = ko.mapping.fromJS({blueprint_identifier: undefined, name: undefined, description: undefined, pages : []})

我用3个元变量和1个数组初始化"this.form"。

然后,我加载数据(也在FormBuilderViewModel中):

ko.mapping.fromJSON(allData, {}, self.form);

变量allData来自AJAX请求,并包含以下内容:{"blueprint_identifier":1347437911,"name":"test","description":"test","pages":[]}

问题是:加载的JSON从未出现在我的页面上。加载数据后console.log(this.form)的输出为空。以下是整个脚本(除了函数等):

var FormBuilderViewModel = function(data){
    var self = this;
    this.form = ko.mapping.fromJS({
                   blueprint_identifier: undefined, 
                   name: undefined, 
                   description: undefined, 
                   pages : []
                })
    $.getJSON("x", function(allData) {
        if(){
            console.log("I'm here");
            ko.mapping.fromJSON(allData, {}, self.form);
        }else{
            // not relevant
        }
    });
    console.log(self.form); 
};

输出是"我在这里"(所以我们到达加载点),然后是空的"form"对象。

我在这里错过了什么?

这里有一个功能齐全的小提琴,可以做你想要的事情:

http://jsfiddle.net/jearles/Cm4xS/

我用一个空的observable初始化表单,然后在AJAX调用返回时加载它。通过使用with绑定,在加载表单之前,我不会尝试显示表单。

$.getJSON函数工作于async,因此当您调用console.log(self.form)时,映射尚未完成。要在控制台输出中看到您的对象,请将日志操作移动到成功功能:

$.getJSON("x", function(allData) {
    if(){
        console.log("I'm here");
        ko.mapping.fromJSON(allData, {}, self.form);
        console.log(self.form);
    }else{
        // not relevant
    }
});

尝试使用ko.mapping.fromJS而不是ko.mapping.fromJSON,因为allData不是预期的fromJSON字符串:

$.getJSON("x", function(allData) {
    if(){
        console.log("I'm here");
        ko.mapping.fromJS(allData, {}, self.form);
        console.log(self.form);
    }else{
        // not relevant
    }
});