form的序列化,即将表单中的键值序列化为可提交的字符串

表单
<form id="target"> <select name="age"> <option value="age1">20</option> <option value="age2" selected>21</option> </select> <input name="name" value="Cynthia"> <label>passsword</label> <input type="password" name="password" value="123456"> <input type="hidden" name="salery" value="3333"> <textarea name="description" cols="15" rows="5">description</textarea> <input type="checkbox" name="hobby" value="football" checked> Football <input type="checkbox" name="hobby" value="basketball"> Basketball <input type="radio" name="sex" value="Female" checked> Female <input type="radio" name="sex" value="Male"> Male </form>
方法一
function serializeForm1(form){
var setForm = "";
for(var key in form){
if(form.hasOwnProperty(key)){
setForm += '"'+form[key].name+'"'+':'+'"'+form[key].value + '"'+',';
}
}
setForm = "{" + setForm.slice(0,setForm.length -1) + "}";
console.log(setForm);
// console.log(JSON.parse(setForm));
return JSON.parse(setForm);
}
// 调用
var oForm = document.getElementById('target');
console.log(serializeForm3(oForm));
结果:
方法二
function serializeForm2(form) {
var parts = [];
for (var i = 0, i1 = form.elements.length; i < i1; i++) {
var field = form.elements[i];
switch (field.type) {
case 'select-one':
case 'select-multiple':
if (field.type.length) {
for (var j = 0, j1 = field.options.length; j < j1; j++) {
var option = field.options[j];
if (option.selected) {
var optionValue = '';
if (option.hasAttribute('value') && option.attributes['value'].specified) {
//specified表明是否有此属性,有的话返回true,若定义了此属性但尚未添加到元素中也返回true。
optionValue = option.value;
} else {
optionValue = optionValue.text;
}
parts.push(encodeURIComponent(field.name) + '=' + encodeURIComponent(optionValue));
}
}
}
break;
case undefined:
case 'file':
case 'submit':
case 'reset':
case 'button':
break;
case 'radio':
case 'checkbox':
if(!field.checked){
break;
}else{
parts.push(encodeURIComponent(field.name) + '=' + encodeURIComponent(field.dataset['index']));
break;
}
default:
if(field.name.length){
parts.push(encodeURIComponent(field.name) + '=' + encodeURIComponent(field.value));
}
}
}
return parts.join('&');
}
// 调用
var oForm = document.getElementById('target');
console.log(serializeForm2(oForm));
结果:
方法三
function serializeForm3(form){
if(!form||form.tagName.toUpperCase()!='FORM'){
return false;
}
var res=[];
var tag,tagType,tagVal,tagName;
for(var i=0;i<form.length;i++){
tag=form[i];
tagType=form[i].type;
tagVal=form[i].value;
tagName=form[i].name;
var reg1=/['textarea'|'text'|'passsword'|'label']/g;
var reg2=/['radio'|'checkbox']/g;
var reg3=/['select']/g;
if(reg1.test(tagType)){
res.push(encodeURIComponent(tagName)+"="+encodeURIComponent(tagVal));
}else if(reg2.test(tagType)&&tag.checked){
res.push(encodeURIComponent(tagName)+"="+encodeURIComponent(tagVal));
}else if(reg3.test(tagType)){
for(var j=0;j<tag.options.length;j++){
if(tag.options[j].selected){
res.push(encodeURIComponent(tagVal)+"="+encodeURIComponent(tag.options[j].value||tag.options[j].text));
}
}
}else{}
}
return res.join(" & ");
}
// 调用
var oForm = document.getElementById('target');
console.log(serializeForm3(oForm));
结果:
以上就是本文的全部内容啦,希望对大家有所帮助~
# form表单序列化提交
# 表单序列化是什么
# 关于jquery form表单序列化的注意事项详解
# jquery form表单序列化为对象的示例代码
# jQuery使用serialize()表单序列化时出现中文乱码问题的解决办法
# 表单序列化与jq中的serialize使用示例
# jquery将一个表单序列化为一个对象的方法
# 基于JavaScript将表单序列化类型的数据转化成对象的处理(允许对象中包含对象)
# jQuery将表单序列化成一个Object对象的实例
# JS中from 表单序列化提交的代码
# 表单
# 中也
# 键值
# 序列化
# textarea
# description
# rows
# cols
# checkbox
# password
# type
# passsword
# salery
# hidden
# Male
# Female
# sex
# nbsp
# function
# js
相关文章:
建站ABC备案流程中有哪些关键注意事项?
建站之星北京办公室:智能建站系统与小程序生成方案解析
西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?
建站之星收费标准详解:套餐费用及年费价格表一览
如何配置支付宝与微信支付功能?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
建站之星下载版如何获取与安装?
公司网站设计制作厂家,怎么创建自己的一个网站?
建站主机如何选?性能与价格怎样平衡?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
广德云建站网站建设方案与建站流程优化指南
如何在云主机上快速搭建多站点网站?
桂林网站制作公司有哪些,桂林马拉松怎么报名?
模具网站制作流程,如何找模具客户?
如何访问已购建站主机并解决登录问题?
如何在服务器上三步完成建站并提升流量?
如何在Windows 2008云服务器安全搭建网站?
如何通过商城免费建站系统源码自定义网站主题?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
建站主机数据库如何配置才能提升网站性能?
网站好制作吗知乎,网站开发好学吗?有什么技巧?
如何通过cPanel快速搭建网站?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
如何用y主机助手快速搭建网站?
建站之星好吗?新手能否轻松上手建站?
C++如何使用std::optional?(处理可选值)
自助网站制作软件,个人如何自助建网站?
如何安全更换建站之星模板并保留数据?
昆明高端网站制作公司,昆明公租房申请网上登录入口?
如何正确选择百度移动适配建站域名?
如何在万网ECS上快速搭建专属网站?
如何在IIS服务器上快速部署高效网站?
宝塔新建站点报错如何解决?
Swift中循环语句中的转移语句 break 和 continue
制作网站的过程怎么写,用凡科建站如何制作自己的网站?
网站微信制作软件,如何制作微信链接?
如何彻底卸载建站之星软件?
建站之星在线版空间:自助建站+智能模板一键生成方案
香港服务器网站卡顿?如何解决网络延迟与负载问题?
建站之星云端配置指南:模板选择与SEO优化一键生成
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
如何在IIS中新建站点并解决端口绑定冲突?
如何在VPS电脑上快速搭建网站?
宝塔建站无法访问?如何排查配置与端口问题?
如何选择服务器才能高效搭建专属网站?
如何高效配置香港服务器实现快速建站?
*请认真填写需求信息,我们会在24小时内与您取得联系。