当前位置: 首页 > 编程日记 > 正文

Jquery 将表单序列化为Json对象

大家知道Jquery中有serialize方法,可以将表单序列化为一个“&”连接的字符串,但却没有提供序列化为Json的方法。不过,我们可以写一个插件实现。

我在网上看到有人用替换的方法,先用serialize序列化后,将&替换成“:”、“‘”:

/** 
* 重置form表单 
* @param formId  form的id  
*/  
function resetQuery(formId){  var fid = "#" + formId;  var str = $(fid).serialize();  //str= cardSelectDate=3&startdate=2012-02-01&enddate=2012-02-04  var ob= strToObj(str);  alert(ob.startdate);//2012-02-01  
}  function strToObj(str){  str = str.replace(/&/g,"','");  str = str.replace(/=/g,"':'");  str = "({'"+str +"'})";  obj = eval(str);   return obj;  
} 

这个方案有个重大bug:如果输入框中本身有=怎么办呢? 所以,我的方法是,先用serializeArray序列化为数组,再封装为Json对象。

表单:
<form id="myForm" action="#"><input name="name"/><input name="age"/><input type="submit"/>
</form>

Jquery插件代码:

(function($){$.fn.serializeJson=function(){var serializeObj={};$(this.serializeArray()).each(function(){serializeObj[this.name]=this.value;});return serializeObj;};
})(jQuery);

测试一下:

$("#myForm").bind("submit",function(e){e.preventDefault();console.log($(this).serializeJson());
});

测试结果:

输入a,b提交,得到序列化结果
{age: "b",name: "a"}

上面的插件,不能适用于有多个值的输入控件,例如复选框、多选的select。下面,我将插件做进一步的修改,让其支持多选。代码如下:

(function($){$.fn.serializeJson=function(){var serializeObj={};var array=this.serializeArray();var str=this.serialize();$(array).each(function(){if(serializeObj[this.name]){if($.isArray(serializeObj[this.name])){serializeObj[this.name].push(this.value);}else{serializeObj[this.name]=[serializeObj[this.name],this.value];}}else{serializeObj[this.name]=this.value; }});return serializeObj;};
})(jQuery);

这里,我将多选的值封装为一个数值来进行处理。如果大家使用的时候需要将多选的值封装为“,"连接的字符串或者其他形式,请自行修改相应代码。

表单:
<form id="myForm" action="#"><input name="name"/><input name="age"/><select multiple="multiple" name="interest" size="2"><option value ="interest1">interest1</option><option value ="interest2">interest2</option><option value="interest3">interest3</option><option value="interest4">interest4</option></select><input type="checkbox" name="vehicle" value="Bike" /> I have a bike<input type="checkbox" name="vehicle" value="Car" /> I have a car<input type="submit"/>
</form>

测试结果:

{age: "aa",interest: ["interest2", "interest4"],name: "dd",vehicle:["Bike","Car"]}

转载于:https://www.cnblogs.com/jianliang-Wu/p/7110730.html

相关文章:

ASP.NET常用函数

Abs(number) 取得数值的绝对值。 Asc(String) 取得字符串表达式的第一个字符ASCII 码。 Atn(number) 取得一个角度的反正切值。 CallByName (object, procname, usecalltype,[args()]) 执行一个对象的方法、设定或传回对象的属性。 CBool(expression) 转换表达式为Boolean …

简单快速修改大量重复代码(Intellij IDEA)

血与泪的教训啊&#xff01;&#xff01;&#xff01;刚开始不知道&#xff0c;一味地疯狂点鼠标和键盘&#xff0c;点到手抽筋才想起来百度一下如何快速修改大量重复代码&#xff0c;呜呜呜~~~ 给大家分享一下吧&#xff0c;可以节约大家大量的时间哦&#xff1a; …

5.3Role和Claims授权「深入浅出ASP.NET Core系列」

5.3Role和Claims授权「深入浅出ASP.NET Core系列」 原文:5.3Role和Claims授权「深入浅出ASP.NET Core系列」希望给你3-5分钟的碎片化学习&#xff0c;可能是坐地铁、等公交&#xff0c;积少成多&#xff0c;水滴石穿&#xff0c;码字辛苦&#xff0c;如果你吃了蛋觉得味道不错&…

電子商務新紀元-WebService With BizSnap

電子商務新紀元-WebService With BizSnap WebService SOAP(Simple Object Access Protocol) Web Services Description Language (WSDL) DELPHI 的SOAP 撰寫WebService Server 程式 撰寫Client 端程式 魔法的秘密 傳送複雜型態資料(Complex Type) 傳送檔案或圖形 處理資料庫 C…

mysql优化1

1.以空间换时间,减少连表查询的次数,适当增加冗余字段 例如: 计算的字段,可以事先统计完,方数据库中,来一个加一个,而不用现场计算 2.字段类型: 整型 > date,time >enum >char >varchar >blob,text 字符串需要考虑字符集和校对集,因此比整型慢 time会考虑时期,用…

用XP做服务器突破10人限制

用XP做服务器突破10人限制用微软提供的小工具 MetaEdit&#xff0c;最新版本是2.2。下载地址:http://download.microsoft.com/download/iis50/Utility/5.0/NT45/EN-US/MtaEdt22.exe安装好以后将树型目录展开至LM \ W3SVC直接在W3SVC文件夹上单击&#xff0c;选择右边列表中Name…

Java反射(详述版)

一、什么是反射&#xff1f; 我们先来看一个例子&#xff1a; package venus; public class Student {public String name;public Student(){System.out.println("无参构造方法");}public void doHomework(){System.out.println(name "正在做作业~~~");…

s9.16作业,员工信息表

转载https://blog.csdn.net/qq_35883464/article/details/83151464 实现员工信息表文件存储格式如下&#xff1a;id&#xff0c;name&#xff0c;age&#xff0c;phone&#xff0c;job1,Alex,22,13651054608,IT2,Egon,23,13304320533,Tearcher3,nezha,25,1333235322,IT 现在需要…

Dubbo+zookeeper使用方法以及注意事项

Dubbozookeeper使用方法以及注意事项最近在一个项目中想做一个数据库查询的服务&#xff0c;目的是将数据库查询这块从程序中脱离出来&#xff0c;形成一个公共的服务平台&#xff0c;大家都可以调用&#xff0c;经过考虑决定选用Dubbozookeeper这个经典的组合来实现&#xff0…

淘淘经受了一次考验...

18日去香港给一个潜在客户做了一次演示&#xff0c;顺便帮淘淘买了一罐奶粉&#xff0c;因为听说香港的奶粉质量比较好&#xff0c;是原装进口的。下午6点多回到深圳&#xff0c;没想到&#xff0c;听到一个不太好的消息。淘淘的奶奶推车带淘淘出去的时候&#xff0c;不小心&am…

使用MasterPage遇到的问题

最近重新拿起.NET&#xff0c;发现一切变的那么的陌生了&#xff0c;发展得真是快啊。。。在使用MasterPage时&#xff0c;要从一个页面的Form提交数据到另一个页面的Form&#xff0c;应该如何处理&#xff1f;不使用MasterPage的时候&#xff0c;可以直接使用PostBackUrl"…

Machine Learning——DAY1

监督学习&#xff1a;分类和回归 非监督学习&#xff1a;聚类和非聚类 1.分类和聚类的区别&#xff1a; 分类(Categorization or Classification)就是按照某种标准给对象贴标签(label)&#xff0c;再根据标签来区分归类。 聚类是指事先没有“标签”而通过某种成团分析找出事物之…

Java的注解

一、注解的概念&#xff1a; 注解并不是一开始就有的&#xff0c;JDK5之前是没有注解的&#xff0c;JDK5及其以后JDK版本才开始支持Java注解&#xff01; Java注解&#xff08;Annotation&#xff09;也叫做元数据&#xff0c;以注解名在代码中存在&#xff0c;它是一种在源代码…

activemq的学习,第一篇

本地的activemq的地址&#xff1a; http://localhost:8161/admin/ win10的启动avtivemq E:\Program Files\ActiveMQ\apache-activemq-5.15.3\bin\win64 win64里面的activemq.bat 消息队列的学习 学习地址2 这是spring集合activemq的地址&#xff1a;github pom.xml引入的依赖&a…

CS Tip 16: 利用注释

译自: http://soup.co.za/weblog/archive/2006/04/07/CS-Tip-16_3A00_-Commenting-out-controls.aspx 当您在修改皮肤时您可以修改任何HTML标记&#xff0c;但是除了带有runat"Server"的除外&#xff0c;删除掉将会产生错误 如果您不想某个控件显示在页面上您可以注释…

今天没有浪费时间,我努力了

7月12日经过暴雨洗礼过的清晨&#xff0c;我晚起了一会&#xff0c;我伧促的洗了把脸&#xff0c;瞪起朦胧胧的双眼&#xff0c;迈着疲惫步子&#xff0c;重复着这条凌乱的街道&#xff0c;10分钟多一点&#xff0c;我就到了公交站点&#xff0c;像往常一样&#xff0c;挤上了8…

动态规划——洛谷_P1057传球游戏

题目&#xff1a; 题目描述 上体育课的时候&#xff0c;小蛮的老师经常带着同学们一起做游戏。这次&#xff0c;老师带着同学们一起做传球游戏。游戏规则是这样的&#xff1a;n个同学站成一个圆圈&#xff0c;其中的一个同学手里拿着一个球&#xff0c;当老师吹哨子时开始传球&…

多线程1(进程、[创建]线程与生命周期)

一、进程与线程 什么是进程&#xff1f;我们先说说什么是程序&#xff1f; 程序&#xff08;Program&#xff09;是为实现特定目标或解决特定问题而用计算机语言&#xff08;比如Java、C等&#xff09;编写的命令序列的集合。 进程&#xff08;process&#xff09;就是指一个程…

网络操作系统第四章

1. 磁盘的数据结构包括哪些内容&#xff1f; 答&#xff1a;分区&#xff0c;卷&#xff0c;磁盘分区&#xff0c;主分区&#xff0c;扩展分区&#xff0c;逻辑分区&#xff0c;逻辑驱动器&#xff0c;引导分区。 2. 什么是基本磁盘和动态磁盘&#xff1f; &#xff08;…

广播风暴系列专题(一)广播风暴:发现-端口

近日防火墙经常地检测到"svchost UDP/连入192.168.1.255/137 192.168.1.66/137 1055656/1065732 UDP_WAIT 过滤 8:48:31 C:\WINDOWS\system32\svchost.exe";"services UDP/连出 192.168.1.21/137 192.168.1.255/137 920736/913476 UDP_WAIT 过滤 11:46:3…

显示一个顶层的提示信息

vb里常作&#xff0c;大概的思路就是显示一个顶层的窗体&#xff0c;提示暂时不要动。c&#xff03;里更简单了MsgDlg msgnewMsgDlg(); msg.TopMosttrue; msg.Show(); System.Windows.Forms.Application.DoEvents();

ArcGIS Engine开发-TOCControl中实现图层的拖放

TOCControl非常好&#xff0c;不用写一行代码就可以将整个地图的图层信息况显示出来&#xff1b;TOCControl也非常坏&#xff0c;提供的接口非常少&#xff0c;我认为有用的只有三个&#xff1a;HitTest,SetBuddyControl,Update&#xff0c;而且Update方法一执行&#xff0c;整…

多线程2(常用的方法:join、interrupt、currentThread、isAlive、setDaemon...)

常用的方法&#xff1a; 1、join()方法&#xff1a;join()方法&#xff1a;执行该方法的线程进入阻塞状态&#xff0c;直到调用该方法的线程结束后再由阻塞状态转为就绪状态。 示例&#xff1a; package venus;import java.util.Date;public class Test {public static void m…

Oracle总结第二篇【视图、索引、事务、用户权限、批量操作】

前言 在Oracle总结的第一篇中&#xff0c;我们已经总结了一些常用的SQL相关的知识点了…那么本篇主要总结关于Oralce视图、序列、事务的一些内容… 在数据库中&#xff0c;我们可以把各种的SQL语句分为四大类… &#xff08;1&#xff09;DML&#xff08;数据操纵语言&#xff…

物联网应用介绍

•物联网的研究背景&#xff08;概念 | 本质 | 特征 | 发展现状&#xff09;物联网是新一代信息技术的高度集成和综合运用&#xff0c;已成为全球新一轮科技革命与产业变革的核心驱动和经济社会绿色、智能、可持续发展的关键基础与重要引擎。国家十三五规划纲要明确提出“积极推…

Oracle使用手册(三)---存储过程与触发器

--存储过程/**//*--1.过程的语法结构--参见:http://newland.cnblogs.com/archive/2006/04/05/367531.html--2.执行存储过程begin 存储过程名;end;--创建好的存储过程可以被任何程序调用*/--3.带参数的存储过程/**//* 参数类型 在PL/SQL过程中&#xff0c;可以有3种类型的…

数据结构之【线性表】(顺序表、链表的基本操作实现)

概念线性表&#xff1a;是N个数据元素的有限序列。 顺序表&#xff1a;用一组地址连续的存储单元依次存储【线性表 】的数据元素。&#xff08;区别于有序表&#xff1a;表中的数据元素存在非递增或非递减有序&#xff09; 链表&#xff1a;用一组任意的存储单元来存储【线性表…

基于android的天气预报的设计与实现

目录 应用开发技术及开发平台介绍应用需求分析应用功能设计及其描述应用UI展示①开发技术&#xff1a; 本系统是采用面向对象的软件开发方法&#xff0c;基于Android studio开发平台&#xff0c;以Android作为本系统的开发语言实现音乐播放器预定的需求功能。 ②平台介绍 硬件平…

敏捷开发有感!

http://sd.csdn.net/n/20060913/94713.html1.我们最优先要做的是通过尽早的&#xff0c;持续的交付有价值的软件来使客户满意。有一篇文章分析了对于公司构建高质量产品方面有帮助的软件开发实践&#xff0c;其中一个实践表明尽早的交付具有部分功能的系统和系统质量之间具有很…

ng 表单提交验证

http://www.runoob.com/try/try.php?filenametry_ng_validate 转载于:https://www.cnblogs.com/alvin553819/p/7127226.html