Home > Backend Development > C#.Net Tutorial > Share an example analysis of how Asp.Net MVC4 implements updating form content through id

Share an example analysis of how Asp.Net MVC4 implements updating form content through id

黄舟
Release: 2017-07-18 10:36:37
Original
1348 people have browsed it

Once a form is created, most of its fields cannot be edited. Only some of these fields can be edited. This article will share with you a detailed explanation of the idea of ​​updating form content through id in Asp.Net MVC4. Friends who need it can refer to it

The user demand is: once a form is created, most of the fields cannot be edited. . Only some of these fields can be edited.

The non-editability is achieved by setting the disabled attribute on the input input box. Then at this time, an error will be reported directly to the content in the submit form in the database, because some fields that cannot be null cannot be used at all due to the disabled attribute. The frontend is fetched and then updated to the database.

There are two ideas:

1. By creating a hidden form, create a hidden control for each disabled control, but this way The problem is that the workload is too large (if the form has a thousand attributes, you will understand)

2. By getting the id of the form in the database, pass the id and editable fields to the background. First, the object and its attribute data are searched from the database by id, and then the editable fields are assigned to the object. After processing is completed, the object's data is updated to the database.

To sum up, using the second way of thinking can appear wiser.

The following are the specific steps: (You don’t need to read the specific steps in detail, they are extracted from the project and are only suitable for my own review)

1. In OutsourcingModule.cs Create a route in to create an access path:


routes.MapRoute(
  "OutSourcingWorkSheet",//路由名
  "outsourcing/saveWorkSheet",//url路径
  new {controller = "Outsourcing", action = "SaveWorkSheet"}//映射的控制器以及对应的Action方法名
);
Copy after login

2.


/// <summary>
/// 保存工作票
/// ModelBinder会将前端传递过来的id在数据库中搜索出字段并且转换为outsourcing对象
/// 此时的outsourcing对象中的workSheets属性不是前端传递过来的值,而是数据库中的
/// 
/// 方法中有两个参数,outsourcing上面已经解释,workSheets是前端传递过来的第二个参数
/// </summary>
/// <param name="outsourcing"></param>
/// <param name="workSheets"></param>
/// <returns></returns>
[HttpPost]
[ActionName("SaveWorkSheet")]
[AccessRestriction("SaveWorkSheet")]
public JsonResult SaveWorkSheet(Outsourcing outsourcing,string workSheets)
{
  if (outsourcing!=null)
  {
    outsourcing.WorkSheets = workSheets;
    _outsourcingService.Save(outsourcing);
    return Json(new ABResponse(HttpStatusCode.OK));
  }
  return Json(new ABResponse(HttpStatusCode.BadRequest));
}//AB为内部项目
Copy after login

3. Front-end js script code


$(&#39;#btn_saveWorkSheet&#39;).on(&#39;click&#39;, function () {
  if ($("input[name=workSheets]").val() == "") {
    bootbox.alert("不能为空");
  } else {
    $.ajax({
      type: "post",
      url: "/outsourcing/saveWorkSheet",
      data: {
        ID: $("#outsourcing_id").val(),
        WorkSheets: $("input[name=workSheets]").val()
      },
      dataType: "json",
      success: function (data) {
        if (data.Code == 200) {
          bootbox.alert("修改成功,即将刷新");
          setTimeout(function () {
            location.reload();
          }, 1000);
        } else {
          bootbox.alert("提交失败,请稍后再试");
        }
      }
    });
  }
});
Copy after login

In fact, the idea is very simple, but I worked on it for most of the day - -; I also encountered a big pit:

In the parameter list of the second code, I initially wrote the string workSheets as WorkSheets. At this time, a blue wavy line appeared under the text. After Alt+Enter, the system prompted Rename to workSheets, so I just pressed Enter to confirm. Then the WorkSheets field can no longer be saved or read from the database. After a long search with the help of a colleague, I discovered that it turned out that during the process of changing uppercase to lowercase, the fields in the dbml file were also changed to lowercase, which resulted in the inability to match the database.

Some knowledge I learned while doing this function:

If the id of an input is apple, it can be obtained like this. This is what I already knew:


var apple = $("#apple").val();
Copy after login

If the name of an input is apple, then it can be obtained like this. This is what I just learned:


var apple = $("input[name=apple]").val();
Copy after login

There is another one I just learned that if you remove a certain name from many inputs:


$("#fruit").find("input:not(input[name=apple]),textarea,select").attr("disabled", true);
//从id为fruit的父元素里面寻找所有的input、textarea和select控件以及其值,但是除去name为apple的控件
Copy after login

In addition, I will summarize the ajax method. I have almost forgotten it after not using it for a long time:


$.ajax({
  type:"post",//可以选择post或者method
  url:"",//url接口
  data:{
    //参数列表
  },
  success:function(data){
    //如果访问url成功,data就是该url接口自动返回的数据
  }
})
Copy after login

Summary

The above is the detailed content of Share an example analysis of how Asp.Net MVC4 implements updating form content through id. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template