gpt4 book ai didi

jquery - Kendo MVVM 绑定(bind)添加/插入项目,如何?

转载 作者:行者123 更新时间:2023-12-01 04:54:55 24 4
gpt4 key购买 nike

我定义了一个具有传输方法(创建、读取、更新和销毁)的剑道数据源以及架构定义:

$(document).ready(function() {
var viewModel = kendo.observable({
dsMedication: new kendo.data.DataSource({
type: "json",
serverFiltering: true,
serverPaging: true,
pageSize: 6,
error: function(e) {
//alert(e.responseText);
//var error_obj = $.parseJSON(e.responseText);
//if (error_obj.Message != null) {
//alert(error_obj.Message);
//}
},
transport: {
read: {
contentType: "application/json; charset=utf-8",
type: "POST",
url: "../Services/svcMedication.asmx/SearchMedication",
dataType: "json",
cache: false
},
update: {
contentType: "application/json; charset=utf-8",
type: "POST",
url: "../Services/svcMedication.asmx/SaveMedication",
dataType: "json",
cache: false
},
destroy: {
url: "../Services/svcMedication.asmx/DeleteMedication",
type: "DELETE",
dataType: "json",
cache: false
},
create: {
contentType: "application/json; charset=utf-8",
type: "POST",
url: "../Services/svcMedication.asmx/SaveMedication",
cache: false
},
parameterMap: function(options, operation) {
if (operation !== "read" && options.models) {
return kendo.stringify({ models: options.models });
}
options.MedicationParam = $('#acMedications').val();
return kendo.stringify(options);
}
},
batch: true,
schema: {
data: "d",
model: {
id: "MedicationId",
fields: {
MedicationId: {
type: "number",
editable: false // this field is not editable
},
Name: {
type: "text",
validation: { // validation rules
required: true // the field is required
}
}
}
}
}
}),
SelectedMedication: null,
HasChanges: false,
save: function() {
//if (this.SelectedMedication == null) {
//this.dsMedication.add({ MedicationId: this.get("MedicationId"), Name: this.get("Name") });
//}
this.dsMedication.sync();
this.set("HasChanges", false);
},

remove: function() {
if (confirm("Are you sure you want to delete this record?")) {
this.dsMedication.remove(this.SelectedMedication);
this.set("SelectedMedication", this.dsMedication.view()[0]);
this.change();
}
},
showForm: function() {
return this.get("SelectedMedication") !== null;
},
change: function() {
this.set("HasChanges", true);
}
});

kendo.bind($("#fmMedication"), viewModel);
});

我的表单元素包含表单元素的适当数据绑定(bind)属性,并且我正在调用 kendo.bind 传递表单。目标是该表单用于添加编辑记录。

如果我搜索一个项目并对其进行更改,一切都会变得非常顺利!

我的问题是:

我不知道如何编写代码来初始化表单,以添加新记录到数据源。

我一直未能在任何地方找到这方面的示例或资源!!

如有任何帮助,我们将不胜感激!谢谢!

最佳答案

基本上,由于您没有明确定义模型,因此您无法轻松创建它的实例。因此,如果您单独声明了模型,如 here - 创建实例会更容易一些,而且您很可能知道下一步该做什么。

在您的情况下,您可以像这样创建模型实例:

var newRecord = new viewModel.dsMedication.reader.model();

一旦有了新记录,您就可以通过 add 或 insert 方法轻松将其添加到数据源(文档中对此都有描述)。

最后,当您在本地添加记录时(您应该能够立即在屏幕上看到更改),您可以调用数据源的 sync 方法来发送这些要保存的新记录在服务器上 - 将使用创建传输选项。

关于jquery - Kendo MVVM 绑定(bind)添加/插入项目,如何?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15069729/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com