国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

form表單序列化詳解(推薦)

2019-11-19 15:47:49
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

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);  }     // 調(diào)用  var oForm = document.getElementById('target');  console.log(serializeForm3(oForm));

結(jié)果:

方法二

 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表明是否有此屬性,有的話(huà)返回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('&');  }     // 調(diào)用  var oForm = document.getElementById('target');    console.log(serializeForm2(oForm));

結(jié)果:

方法三

 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(" & ");  }     // 調(diào)用  var oForm = document.getElementById('target');  console.log(serializeForm3(oForm));

結(jié)果:

以上就是本文的全部?jī)?nèi)容啦,希望對(duì)大家有所幫助~

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 温宿县| 海南省| 茶陵县| 杭锦后旗| 石楼县| 苍溪县| 麻阳| 红桥区| 政和县| 临桂县| 大足县| 广东省| 深州市| 抚顺县| 瑞金市| 滁州市| 淮南市| 新龙县| 安达市| 永善县| 洪泽县| 汶川县| 闽侯县| 高安市| 当雄县| 怀仁县| 绥芬河市| 耒阳市| 杨浦区| 肥乡县| 镇沅| 横山县| 通海县| 永顺县| 绥滨县| 马尔康县| 马尔康县| 景洪市| 吴川市| 彭山县| 蓬溪县|