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
相关文章:
如何撰写建站申请书?关键要点有哪些?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
如何正确下载安装西数主机建站助手?
如何在云虚拟主机上快速搭建个人网站?
香港服务器部署网站为何提示未备案?
Python lxml的etree和ElementTree有什么区别
建站之星后台管理如何实现高效配置?
建站之星后台密码如何安全设置与找回?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
如何在服务器上配置二级域名建站?
如何快速查询网站的真实建站时间?
,巨量百应是干嘛的?
制作网站的模板软件,网站怎么建设?
如何在建站主机中优化服务器配置?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
济南专业网站制作公司,济南信息工程学校怎么样?
建站之星后台密码遗忘?如何快速找回?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
c# 在高并发下使用反射发射(Reflection.Emit)的性能
如何通过服务器快速搭建网站?完整步骤解析
深圳网站制作平台,深圳市做网站好的公司有哪些?
用v-html解决Vue.js渲染中html标签不被解析的问题
网站制作的方法有哪些,如何将自己制作的网站发布到网上?
如何在阿里云ECS服务器部署织梦CMS网站?
如何配置WinSCP新建站点的密钥验证步骤?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
如何通过网站建站时间优化SEO与用户体验?
模具网站制作流程,如何找模具客户?
如何批量查询域名的建站时间记录?
北京的网站制作公司有哪些,哪个视频网站最好?
寿县云建站:智能SEO优化与多行业模板快速上线指南
如何选择高效便捷的WAP商城建站系统?
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
建站之星如何快速解决建站难题?
如何快速生成高效建站系统源代码?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
网站制作说明怎么写,简述网页设计的流程并说明原因?
如何通过商城自助建站源码实现零基础高效建站?
如何用y主机助手快速搭建网站?
网站app免费制作软件,能免费看各大网站视频的手机app?
建站上传速度慢?如何优化加速网站加载效率?
如何在阿里云域名上完成建站全流程?
如何制作算命网站,怎么注册算命网站?
b2c电商网站制作流程,b2c水平综合的电商平台?
建站主机是什么?如何选择适合的建站主机?
建站之星如何优化SEO以实现高效排名?
如何在七牛云存储上搭建网站并设置自定义域名?
常州企业建站如何选择最佳模板?
一键制作网站软件下载安装,一键自动采集网页文档制作步骤?
*请认真填写需求信息,我们会在24小时内与您取得联系。