• 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);
    }

  • 相关阅读:
    Authentication with SignalR and OAuth Bearer Token
    [Web API] 如何让 Web API 统一回传格式以及例外处理[转]
    EF6 Database First (DbContext)
    DbContext运行时动态附加上一个dbset
    命令模式
    责任链模式
    策略模式
    Sql Server isnull() 用法
    状态者模式
    dom元素改变监听
  • 原文地址:https://www.cnblogs.com/Vam8023/p/2975839.html
Copyright © 2020-2023  润新知