今天发现,如果用Ajax跟EF对数据进行删除的时候遇到的问题,刚开始是一直报一个错:“无法更新 EntitySet“Ips_Articles”,因为它有一个 DefiningQuery,而 <ModificationFunctionMapping> 元素中没有支持当前操作的 <InsertFunction> 元素”,如果用EF报这个错的话,就肯定是数据表里没有设置主键,只要重新设置主键,在添加EF的话,问题就解决了;
然后,这个改正之后,就发现jsonRes拿不到值,可是,数据却已经删除,问题出在哪呢?错在两个地方:1.返回的字符串要是转义的,除非是值类型;2.要用Content返回。
前台页面的Ajax代码:
function doDel(btnDel) {
if (confirm("您确定要删除吗?")) {
$.post("/Home/DoDel/" + btnDel.getAttribute("cid"), "", function (jsonRes) {
if (jsonRes.statu == "ok") {
var trDel = btnDel.parentNode.parentNode;
trDel.parentNode.removeChild(trDel);
alert("成功删除啦");
}
else {
alert("删除不了");
}
}, "json");
}
}
Constroller里的代码:
//根据传过来的Id进行数据删除
public ActionResult DoDel(int id)
{
DemoTestEntities db = new DemoTestEntities(); //EF对象
MyTestTable mtb = (from s in db.MyTestTables where s.Id == id select s).SingleOrDefault();
db.MyTestTables.Remove(mtb);
db.SaveChanges();
//必须要用转义符进行转义 --"{'statu':'ok'}"这种情况都是不允许的
string jsonStr = "{\"statu\":\"ok\"}";
//返回数据的如果不用Content的话,Ajax接收到的会是Undefined
return Content(jsonStr);
}