背景:最近在做项目时,由于编辑页面需要提交的数据量有些多,而且在提交前还需要做一些逻辑处理,所以如果按照正常的方式,一个个的获取值然后拼接json对象传到后台的话相对工作量较大,而且容易出错,后期的维护工作也相对困难,于是爱偷懒的我就像能不能有个办法不用一个个的去获取值,拼json对象,还能直接以与数据库表结构相同的model的方式接收数据呢?就我所知的好像目前现有的方式都是通过序列化插件什么的,而我当时也有考虑用这个,但是我觉得这些插件尤其让人人用着不爽的缺点:

(1)需要提交的内容必须在<form>标签内

(2)序列化后的json包含<form>里面的全部表单内容

(3)无法满足一些个性化要求(如多选时以","隔开;既需要去下拉框的value也需去text)

而我的项目中有以下几个要求

(1) 部分数据在母版页中(会随着用户的不同操作而改变)

(2)用户不同操作,提交的数据也不一致

(3)有些数据需要做特殊处理

有的朋友可能会说既然这样那你完全可以把form放在母版页里呀, 处理好的数据放在页面的隐藏域利亚.可是如果这样处理的话那么提交的内容将相当多,隐藏域也相当的多,所以我选择了用以下方式:

为了方便理解以下代码均做了简化处理

html如下:

 <div id="demos">
<input id="Id" type="hidden" value="14" />
<input id="ActivityName" type="text" value="" />
<input id="ActivityContent" type="text" value="" />
<input id="ActivityTime" type="text" value="" />
<input id="ActivityAddress" type="text" value="" />
<input id="PersonInChage" type="text" value="" />
<input id="Field1" type="text" value="" />
<input id="Field2" type="text" value="" />
<input id="Field3" type="text" value="" />
<input id="Field4" type="text" value="" />
</div>

js如下

  function GetFormParamsInfo() {
var jsonModle = {};
$("#demos input").each(function () {
var fieldName = $(this).attr("id");
var fieldValue = $(this).val();
jsonModle[fieldName] = fieldValue;
});
return jsonModle;
}; $.ajax({
type: "POST",
url: "Home/Index",
data: GetFormParamsInfo(),
success: function (msg) {
//.....
}
});

以上代码中GetFormParamsInfo方法中可以在return之前任意的添加自己特定处理的代码如

if(a==b)

{

  jsonModle["xxx"] = xxxx;

}else{

jsonModle["xxxxx"] = xxxxxxxxx;

}

return  jsonModle;

等等,可以任意的去

后台代码:

 public class HomeController : Controller
{
public ActionResult Index(ViewModcl model)
{
//处理
return View();
} } public class ViewModcl
{
public string Id { set; get; }
public string ActivityName { set; get; }
public string ActivityContent { set; get; }
public string ActivityTime { set; get; }
public string ActivityAddress { set; get; }
public string PersonInChage { set; get; }
public string Field1 { set; get; }
public string Field2 { set; get; }
public string Field3 { set; get; }
public string Field4 { set; get; } }

说明如下:

html中的需要提交的内容之div中 然后我获取需要提交的内容时只需要通过each遍历组装成json对象,然后通过ajax直接提交到后台,而后台以实体类对象方式直接接收就好了

有点:

1,无需form

2,可以任意制定参数规则

3,提交最小数量的数据内容(不相关的数据都不提交)

4,几乎无需隐藏域(编辑时存储id)

由于个人能力有限,自然有些考虑不到的,还望各位路过的大牛们能帮忙指点指点,小弟在此先谢谢了.

另类的表单数据"序列化"的更多相关文章

  1. jQuery对的表单数据序列化和校验

    jQuery对的表单数据序列化和校验 表单序列化 如果想让表单通过ajax异步提交,那么首先我们要通过js获取到每个表单中输入的值,如果表单项比较多的话,是一件很麻烦,很痛苦的事情,那么我们可以通过j ...

  2. Ajax--serialize应用表单数据序列化

    一.jQuery+Ajax表单数据序列化 <!DOCTYPE html> <html> <head> <meta charset="UTF-8&qu ...

  3. 将任意一个jQuery对象进行表单序列化,免除了提交请求时大量拼写表单数据的烦恼,支持键值对<name&value>格式和JSON格式。

    http://zhengxinlong.iteye.com/blog/848712 将任意一个jQuery对象进行表单序列化,免除了提交请求时大量拼写表单数据的烦恼,支持键值对<name& ...

  4. 序列化表单数据$("form").serializeArray()

    在做一个后台管理系统类似的项目中发现不能直接取得表单中的数值,于是想到先将表单数据转化为json,然后再用js从json中获取数据,那不就简单了吗? 于是我用了jquery的serializeArra ...

  5. jquery ajax异步提交表单数据的方法

    使用jquery的ajax方法可以异步提交表单,成功后后台返回json数据,回调函数处理,可以不用刷新页面,达到异步的目的: 处理表单的数据可以用serialize()方法进行序列化,而如果提交的数据 ...

  6. django(7)modelform操作及验证、ajax操作普通表单数据提交、文件上传、富文本框基本使用

    一.modelForm操作及验证 1.获取数据库数据,界面展示数据并且获取前端提交的数据,并动态显示select框中的数据 views.py from django.shortcuts import ...

  7. Ajax提交表单数据(包含文件)

    1. 表单数据->JSON->后台 2. 表单序列化[方式一] jquery.serializejson.js <script src="/js/jquery.serial ...

  8. jsp提交表单数据乱码,内置对象,以及过滤器

    jsp提交表单数据乱码解决方案 通过form表单给服务器提交数据的时候,如果提交的是中文数据,那么可能会出现乱码,如果表单的请求方式是post请求,那么可以使用如下方案解决乱码: 在调用getPara ...

  9. Struts2中Action取得表单数据的几种方法

    Struts2中Action取得表单数据的几种方法   Struts2中Action获得表单数据的几种方法struts2 Action获取表单传值 1.通过属性驱动式JSP: <form act ...

随机推荐

  1. JavaScript 嵌套 书名号 查询

    字符串中查找嵌套书名号 ,一开始想用正则来做的,最后发现正则不可能达到我的需求(可能是我正则理解不够,哈哈),所以写下了这个方法:只做了三层,如果你要更多,可以自己添加,哈哈//提取查询关键字,sou ...

  2. 关于ZedGraph

    http://www.codeproject.com/Articles/5431/A-flexible-charting-library-for-NET

  3. SQL注入以及如何防止和索引

    SQL注入产生的原因:程序开发过程中不注意规范书写sql语句和对特殊字符进行过滤,导致客户端可以通过全局变量POST和GET提交一些sql语句正常执行. 防止SQL注入: 1.开启配置文件中的magi ...

  4. 用 IIS 实现请求转发

    最近部门要开发一个简单的APP,部分数据是现有项目已经存在的,为了方便维护,希望只提供一个交互的入口,并且协议的规则不变. 基于这个需求,有两套解决方案: 1.用代码将现有的api封装一层,对请求数据 ...

  5. UWP Jenkins + NuGet + MSBuild 手把手教你做自动UWP Build 和 App store包

    背景 项目上需要做UWP的自动安装包,在以前的公司接触的是TFS来做自动build. 公司要求用Jenkins来做,别笑话我,之前还真不晓得这个东西. 会的同学请看一下指出错误,不会的同学请先自行脑补 ...

  6. angular使用select时要注意的坑

    一.错误使用产生的坑--留白 公司前段时间要搞一个后台系统,为了快选了angular,在使用select标签的时候碰到一个小问题,首先我们先来看坑图,如图1所示. 如图所示,出现了留白,也就是当我们使 ...

  7. hdu3534 树的直径变形

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=3534 题意:n 之后 n-1条边,l,r,w:求出树上的最长路径以及最长路径的条数. // ...

  8. 二分+DP+Trie HDOJ 5715 XOR 游戏

    题目链接 XOR 游戏 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total ...

  9. 聊一聊 JSONP

    JSONP 说到 JSONP 就要说到同源策略(Same Origin Policy), 同源策略是浏览器最核心的也是最基本的安全功能. 浏览器的同源策略,限制了来自不同源的 “document” 或 ...

  10. bzoj2243树链剖分+染色段数

    终于做了一道不是一眼出思路的代码题(⊙o⊙) 之前没有接触过这种关于染色段数的题目(其实上课好像讲过),于是百度了一下(现在思维能力好弱) 实际上每一段有用的信息就是总共有几段和两段各是什么颜色,在开 ...