form表单序列化详解(推荐)


Posted in Javascript onAugust 15, 2017

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));

结果:

form表单序列化详解(推荐)

方法二

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));

结果:

form表单序列化详解(推荐)

方法三

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表单序列化详解(推荐)

以上就是本文的全部内容啦,希望对大家有所帮助~

Javascript 相关文章推荐
JS getMonth()日期函数的值域是0-11
Feb 15 Javascript
根据身份证号自动输出相关信息(籍贯,出身日期,性别)
Nov 15 Javascript
js实现浏览器窗口大小被改变时触发事件的方法
Feb 02 Javascript
javascript下使用Promise封装FileReader
Feb 19 Javascript
jQuery 更改checkbox的状态,无效的解决方法
Jul 22 Javascript
JavaScript实现DOM对象选择器
Sep 24 Javascript
jQuery双向列表选择器select版
Nov 01 Javascript
jQuery使用正则验证15/18身份证的方法示例
Apr 27 jQuery
微信小程序 图片宽高自适应详解
May 11 Javascript
微信小程序网络请求wx.request详解及实例
May 18 Javascript
Koa项目搭建过程详细记录
Apr 12 Javascript
解决Vue.js由于延时显示了{{message}}引用界面的问题
Aug 25 Javascript
JavaScript上传文件时不用刷新页面方法总结(推荐)
Aug 15 #Javascript
JavaScript阻止表单提交方法(附代码)
Aug 15 #Javascript
jQuery DOM节点的遍历方法小结
Aug 15 #jQuery
Mongoose实现虚拟字段查询的方法详解
Aug 15 #Javascript
深入浅析Vue不同场景下组件间的数据交流
Aug 15 #Javascript
React应用中使用Bootstrap的方法
Aug 15 #Javascript
JavaScript函数中的this四种绑定形式
Aug 15 #Javascript
You might like
php之Smarty模板使用方法示例详解
2014/07/08 PHP
PHP中mysql_field_type()函数用法
2014/11/24 PHP
thinkPHP引入类的方法详解
2016/12/08 PHP
PHP中的函数声明与使用详解
2017/05/27 PHP
jquery 模拟类搜索框自动完成搜索提示功能(改进)
2010/05/24 Javascript
javascript基础第一章 JavaScript与用户端
2010/07/22 Javascript
JS+CSS实现仿雅虎另类滑动门切换效果
2015/10/13 Javascript
Vue 项目部署到服务器的问题解决方法
2017/12/05 Javascript
vue移动端UI框架实现QQ侧边菜单组件
2018/03/09 Javascript
Node.js模块全局安装路径配置方法
2018/05/17 Javascript
javascript实现一款好看的秒表计时器
2020/09/05 Javascript
javascript局部自定义鼠标右键菜单
2020/12/08 Javascript
[34:39]Secret vs VG 2018国际邀请赛淘汰赛BO3 第二场 8.23
2018/08/24 DOTA
详细介绍Python语言中的按位运算符
2013/11/26 Python
python获得图片base64编码示例
2014/01/16 Python
Python实现批量检测HTTP服务的状态
2016/10/27 Python
利用Python开发实现简单的记事本
2016/11/15 Python
Python多进程multiprocessing.Pool类详解
2018/04/27 Python
Python错误处理操作示例
2018/07/18 Python
JavaScript中的模拟事件和自定义事件实例分析
2018/07/27 Python
详解Python发送email的三种方式
2018/10/18 Python
PyQt5 多窗口连接实例
2019/06/19 Python
Django框架orM与自定义SQL语句混合事务控制操作
2019/06/27 Python
Python发送邮件实现基础解析
2020/08/14 Python
python实现登录与注册系统
2020/11/30 Python
全面解析CSS Media媒体查询使用操作(推荐)
2017/08/15 HTML / CSS
“型”走纽约上东区:Sam Edelman
2017/04/02 全球购物
土耳其时尚潮流在线购物网站:Trendyol
2017/10/10 全球购物
Noon埃及:埃及在线购物
2019/11/26 全球购物
酒店员工检讨书
2014/02/18 职场文书
党的群众路线对照检查材料
2014/08/27 职场文书
党员三严三实对照检查材料
2014/10/13 职场文书
文明旅游倡议书
2015/04/28 职场文书
禁毒主题班会教案
2015/08/14 职场文书
小学生组织委员竞选稿
2015/11/21 职场文书