另类的表单数据"序列化"
背景:最近在做项目时,由于编辑页面需要提交的数据量有些多,而且在提交前还需要做一些逻辑处理,所以如果按照正常的方式,一个个的获取值然后拼接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)
由于个人能力有限,自然有些考虑不到的,还望各位路过的大牛们能帮忙指点指点,小弟在此先谢谢了.
另类的表单数据"序列化"的更多相关文章
- jQuery对的表单数据序列化和校验
jQuery对的表单数据序列化和校验 表单序列化 如果想让表单通过ajax异步提交,那么首先我们要通过js获取到每个表单中输入的值,如果表单项比较多的话,是一件很麻烦,很痛苦的事情,那么我们可以通过j ...
- Ajax--serialize应用表单数据序列化
一.jQuery+Ajax表单数据序列化 <!DOCTYPE html> <html> <head> <meta charset="UTF-8&qu ...
- 将任意一个jQuery对象进行表单序列化,免除了提交请求时大量拼写表单数据的烦恼,支持键值对<name&value>格式和JSON格式。
http://zhengxinlong.iteye.com/blog/848712 将任意一个jQuery对象进行表单序列化,免除了提交请求时大量拼写表单数据的烦恼,支持键值对<name& ...
- 序列化表单数据$("form").serializeArray()
在做一个后台管理系统类似的项目中发现不能直接取得表单中的数值,于是想到先将表单数据转化为json,然后再用js从json中获取数据,那不就简单了吗? 于是我用了jquery的serializeArra ...
- jquery ajax异步提交表单数据的方法
使用jquery的ajax方法可以异步提交表单,成功后后台返回json数据,回调函数处理,可以不用刷新页面,达到异步的目的: 处理表单的数据可以用serialize()方法进行序列化,而如果提交的数据 ...
- django(7)modelform操作及验证、ajax操作普通表单数据提交、文件上传、富文本框基本使用
一.modelForm操作及验证 1.获取数据库数据,界面展示数据并且获取前端提交的数据,并动态显示select框中的数据 views.py from django.shortcuts import ...
- Ajax提交表单数据(包含文件)
1. 表单数据->JSON->后台 2. 表单序列化[方式一] jquery.serializejson.js <script src="/js/jquery.serial ...
- jsp提交表单数据乱码,内置对象,以及过滤器
jsp提交表单数据乱码解决方案 通过form表单给服务器提交数据的时候,如果提交的是中文数据,那么可能会出现乱码,如果表单的请求方式是post请求,那么可以使用如下方案解决乱码: 在调用getPara ...
- Struts2中Action取得表单数据的几种方法
Struts2中Action取得表单数据的几种方法 Struts2中Action获得表单数据的几种方法struts2 Action获取表单传值 1.通过属性驱动式JSP: <form act ...
随机推荐
- 多个html怎么导入相同的头部导航
1. iframe 包含法.页头和页尾分别做成一个页面,然后通过iframe嵌入到调用的页面.这种方法在页头页尾高度固定的时候比较适用,因为当页头页尾高度不固定时,需要iframe根据页面内容自适应高 ...
- DatePicker 设置字体颜色
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 13.0px Menlo; color: #ffffff } span.s1 { } span.s2 { c ...
- 【leetcode】Valid Sudoku
题目简述: Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules. The Sudoku board cou ...
- UWP VirtualizedVariableSizedGridView 支持可虚拟化可变大小Item的View(一)
Boss的需要时这样的,Item是可变大小的,同时根据不同的Window size,来确定Item的结构和大小Window 小的时候是 大的时候是这样的: 当然这size变化的过程中也允许其他结构,我 ...
- 2.View绘制分析笔记之onMeasure
今天主要学习记录一下Android View绘制三部曲的第一步,onMeasure,测量. 起源 在Activity中,所有的View都是DecorView的子View,然后DecorView又是被V ...
- [leetcode] 题型整理之图论
图论的常见题目有两类,一类是求两点间最短距离,另一类是拓扑排序,两种写起来都很烦. 求最短路径: 127. Word Ladder Given two words (beginWord and end ...
- 前端项目通用、常用js common.js
var url = location.href; if (url.toLowerCase().indexOf("/akweb_admin/") == -1) { function ...
- FFmpeg纯净版解码 av_parser_parse2
主要是通过av_parser_parse2拿到AVPaket数据,跟av_read_frame类似. 输入必须是只包含视频编码数据“裸流”(例如H.264.HEVC码流文件),而不能是包含封装格式的媒 ...
- -webkit-tap-highlight-color
css3中有henduo 新属性,tap-highlight-color;是用于元素在移动设备IOS和adnroid上被触发点击事件时,响应的背景框的颜色. 例如在Adnroid版本的微信中,点击a标 ...
- Tomcat的粗略介绍
因为工作的缘故很多项目启动需要通过Tomcat修改配置文件进行启动项目,所以相应的就了解了下Tomcat便于在以后比我更新的新人面前装逼. 1.bin目录 我们能用到的无非一个启动跟一个关闭没什么好说 ...