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

发布时间 - 2026-01-11 02:47:58    点击率:

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 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Java解压缩zip - 解压缩多个文件或文件夹实例  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  如何生成腾讯云建站专用兑换码?  微信小程序 配置文件详细介绍  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  html如何与html链接_实现多个HTML页面互相链接【互相】  javascript事件捕获机制【深入分析IE和DOM中的事件模型】  Laravel怎么上传文件_Laravel图片上传及存储配置  网站制作大概多少钱一个,做一个平台网站大概多少钱?  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】  微信小程序 闭包写法详细介绍  如何用IIS7快速搭建并优化网站站点?  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  如何在VPS电脑上快速搭建网站?  js实现点击每个li节点,都弹出其文本值及修改  JavaScript如何实现倒计时_时间函数如何精确控制  Laravel如何实现数据库事务?(DB Facade示例)  Laravel如何使用Collections进行数据处理?(实用方法示例)  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  Linux系统运维自动化项目教程_Ansible批量管理实战  EditPlus 正则表达式 实战(3)  如何用腾讯建站主机快速创建免费网站?  php485函数参数是什么意思_php485各参数详细说明【介绍】  JavaScript常见的五种数组去重的方式  Laravel如何使用withoutEvents方法临时禁用模型事件  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  Laravel如何创建自定义Artisan命令?(代码示例)  Laravel如何实现模型的全局作用域?(Global Scope示例)  Laravel Debugbar怎么安装_Laravel调试工具栏配置指南  Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境  如何登录建站主机?访问步骤全解析  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  如何在IIS中新建站点并配置端口与IP地址?  Bootstrap整体框架之JavaScript插件架构  Internet Explorer官网直接进入 IE浏览器在线体验版网址  Laravel如何实现全文搜索功能?(Scout和Algolia示例)  如何在香港服务器上快速搭建免备案网站?  详解CentOS6.5 安装 MySQL5.1.71的方法  Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道  JavaScript模板引擎Template.js使用详解  长沙做网站要多少钱,长沙国安网络怎么样?  node.js报错:Cannot find module &#39;ejs&#39;的解决办法  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  如何快速查询网站的真实建站时间?  网站建设要注意的标准 促进网站用户好感度!  如何在七牛云存储上搭建网站并设置自定义域名?  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】  使用PHP下载CSS文件中的所有图片【几行代码即可实现】