它可以读取远程数据库,它可以在本地创建新项目,但它们实际上并不保存到远程数据库。这是添加新项目的原因:
function addNewItem(){
dataSource.add({id:"0", petName:"Dusty", petSpecies:"Dog", petGender:"M"});
dataSource.sync();
}
$('#addPet').bind('click', addNewItem);
这个函数中的ajax POST调用而不是dataSource东西完美地添加到我的数据库中:
var object = { id:"0", petName:"Dusty", petSpecies:"Dog", petGender:"M" };
$.ajax({
type: "POST",
url: 'website/petData',
headers: { "Authorization" : "Bearer ${AccessToken}" },
contentType: "application/json",
data: JSON.stringify(object)
})
这是我的数据源代码。我需要改变什么?我已经尝试过很多不同的事情,但没有运气。
var dataSource = new kendo.data.DataSource({
type: "everlive",
transport: {
typeName: 'petData',
read: {
url: "website/petData",
dataType: "jsonp"
},
create: {
url: 'website/petData',
dataType: "jsonp"
}
},
group: "petSpecies",
schema: {
model: {
id: "id",
fields: {
id: { type: "number"},
petName: { type: "text" },
petSpecies: { type: "text" },
petGender: { type: "text" }
}
}
}
});
答案 0 :(得分:0)
感谢giltnerj0和Brett的评论,我能够说出正确的词语,并发现我需要做的就是将create的dataType:jsonp改为json。我现在收到一些POST错误,但它最后是POSTing并将内容保存到我的数据库中。
create: {
url: 'website/petData',
dataType: "json"
}