MVC的Ajax传值问题

 

         今天发现,如果用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);
}

posted @ 2013-03-22 16:29  Vam8023  阅读(342)  评论(0编辑  收藏  举报