全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

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 


相关文章: 青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?  如何通过虚拟主机快速搭建个人网站?  如何确保FTP站点访问权限与数据传输安全?  学校为何禁止电信移动建设网站?  建站之星CMS建站配置指南:模板选择与SEO优化技巧  高端云建站费用究竟需要多少预算?  如何在宝塔面板中创建新站点?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  在线制作视频的网站有哪些,电脑如何制作视频短片?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  如何快速生成凡客建站的专业级图册?  网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?  如何在IIS7中新建站点?详细步骤解析  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  如何快速生成专业多端适配建站电话?  广州营销型建站服务商推荐:技术优势与SEO优化解析  如何快速搭建虚拟主机网站?新手必看指南  建站之星代理如何优化在线客服效率?  如何通过建站之星自助学习解决操作问题?  广平建站公司哪家专业可靠?如何选择?  如何正确下载安装西数主机建站助手?  如何选择网络建站服务器?高效建站必看指南  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  如何用好域名打造高点击率的自主建站?  php8.4新语法match怎么用_php8.4match表达式替代switch【方法】  文字头像制作网站推荐软件,醒图能自动配文字吗?  西安专业网站制作公司有哪些,陕西省建行官方网站?  平台云上自助建站如何快速打造专业网站?  微信小程序 input输入框控件详解及实例(多种示例)  成都响应式网站开发,dw怎么把手机适应页面变成网页?  建站之星后台密码如何安全设置与找回?  c++ stringstream用法详解_c++字符串与数字转换利器  如何快速搭建高效WAP手机网站?  网站制作公司排行榜,四大门户网站排名?  c# 服务器GC和工作站GC的区别和设置  如何配置IIS站点权限与局域网访问?  如何彻底卸载建站之星软件?  建站主机解析:虚拟主机配置与服务器选择指南  如何通过FTP服务器快速搭建网站?  外汇网站制作流程,如何在工商银行网站上做外汇买卖?  建站之星代理平台如何选择最佳方案?  小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化  网站制作公司排行榜,抖音怎样做个人官方网站  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  如何通过FTP空间快速搭建安全高效网站?  个人网站制作流程图片大全,个人网站如何注销?  如何高效配置香港服务器实现快速建站?  如何通过西部数码建站助手快速创建专业网站?  建站主机功能解析:服务器选择与快速搭建指南 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。