溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

js獲取form表單數(shù)據(jù)的方法

發(fā)布時(shí)間:2020-04-09 13:45:40 來源:億速云 閱讀:511 作者:小新 欄目:web開發(fā)

今天小編給大家分享的是js獲取form表單數(shù)據(jù)的方法,很多人都不太了解,今天小編為了讓大家更加了解js獲取form表單數(shù)據(jù)的方法,所以給大家總結(jié)了以下內(nèi)容,一起往下看吧。一定會有所收獲的哦。

js獲取form表單數(shù)據(jù)的方法

方法如下:

1、有的時(shí)候想偷點(diǎn)懶,頁面上有大量的表單提交數(shù)據(jù),每次單獨(dú)獲取都比較麻煩。代碼冗余度也比較多,因此封裝了一個(gè)方法。

2、表單元素必須要有name屬性,name屬性是向后端提交的字段數(shù)據(jù)。

3、html代碼

<h5>下拉框</h5>
 <select name="sel" id="sel" class="query">
  <option value ="sel-1">sel-1</option>
  <option value ="sel-2">sel-2</option>
 </select>
 <h5>輸入框</h5>
 <input type="text" name="text1" class="query" value="hello" />
 <input type="text" name="text2" class="query" value="word" />
 <h5>密碼框</h5>
 <input type="password" name="password" class="query" value="123456" />
 <h5>單選框</h5>
 單選1<input type="radio" name="radio" class="query" value="r1" checked />
 單選2<input type="radio" name="radio" class="query" value="r2" checked/>
 單選3<input type="radio" name="radio" class="query" value="r3" />
  <h5>復(fù)選框</h5>
 復(fù)選框1<input type="checkbox" name="check" id="" class="query" value="c1" checked/>
 復(fù)選框2<input type="checkbox" name="check" id="" class="query" value="c2" />
 復(fù)選框3<input type="checkbox" name="check" id="" class="query" value="c3" checked/>
 <h5>search</h5>
 <input type="range" name="range" id="" class="query" value="" />
 <input type="color" name="color" id="" class="query" value="" />
 <h5>
  <button type="button" id="save">
   提交
  </button>
 </h5>

4、此處引入了JQ庫。

4.1、js代碼塊

使用說明:調(diào)用方法的時(shí)候傳入class名稱即可。

// 封裝方法,獲取到form表單的數(shù)據(jù)。使用此方法,表單元素必須存在那么屬性。
  //el:元素的class名稱。
  function getParameter(el){
   var obj={};
   $(el).each(function(index,item){
    // 判斷元素的類型
    if(item.type=="text" || item.type=="password" || item.type=="select-one" || item.type=="tel" || 
     item.type=="search" || item.type=="range" || item.type=="number" || item.type=="month" || 
     item.type=="email" || item.type=="datetime-local" || item.type=="datetime" || item.type=="date" || 
     item.type=="color"){
     //獲取到name的值,name的值就是向后臺傳遞的數(shù)據(jù)
     obj[$(this).attr("name")]=$(this).val();
    }else if(item.type=="checkbox"){
     var stamp=false;
     if($(this).attr("name") && !stamp){
      stamp=false;
      // 獲取到復(fù)選框選中的元素
      var checkboxEl=$("input[name="+$(item).attr('name')+"]:checked");
      if(checkboxEl){
       var checkboxArr=[];
       // 取出復(fù)選框選中的值
       checkboxEl.each(function(idx,itm){
        checkboxArr.push($(itm).val());
       });
       obj[$(this).attr("name")]=checkboxArr.join(",");
      }
      
     }
    }else if(item.type=="radio"){
     // 獲取到單選框選中的值
     var radio_val=$("input[name="+$(item).attr('name')+"]:checked").val();
     if(radio_val){
      obj[$(item).attr("name")]=radio_val;
     }
    }
   });
   return obj;
  }
  // 調(diào)用方法
  $("#save").click(function(){
     var parameter=getParameter(".query");
       console.log(parameter); 
     });

關(guān)于js獲取form表單數(shù)據(jù)的方法就分享到這里了,當(dāng)然并不止以上和大家分析的辦法,不過小編可以保證其準(zhǔn)確性是絕對沒問題的。希望以上內(nèi)容可以對大家有一定的參考價(jià)值,可以學(xué)以致用。如果喜歡本篇文章,不妨把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI