zoukankan      html  css  js  c++  java
  • 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);
    }

  • 相关阅读:
    数据库镜像搭建
    关于开发人员数据库权限配置以及规范数据库升级流程
    带CheckBox列头的DataGridView
    查询整个数据库中某个特定值所在的表和字段的方法
    SQL Server 2008中获取数据库所有表及其字段名称、类型、长度的SQL
    关于已经上线项目的升级的启示
    SQL语句恢复数据库时一直显示“正在还原”
    带CheckBox列头的DataGridView(一)
    SQL Server中事务处理的注意事项
    group by 使用
  • 原文地址:https://www.cnblogs.com/Vam8023/p/2975839.html
Copyright © 2011-2022 走看看