利用JS如何獲取form表單數(shù)據(jù)
前言
本文主要給大家介紹的是關(guān)于利用JS獲取form表單數(shù)據(jù)的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹吧
方法如下:
1.有的時候想偷點(diǎn)懶,頁面上有大量的表單提交數(shù)據(jù),每次單獨(dú)獲取都比較麻煩。代碼冗余度也比較多,因此封裝了一個方法。
2. 表單元素必須要有name屬性,name屬性是向后端提交的字段數(shù)據(jù)。
3.html代碼
<h3>下拉框</h3> <select name="sel" id="sel" class="query"> <option value ="sel-1">sel-1</option> <option value ="sel-2">sel-2</option> </select> <h3>輸入框</h3> <input type="text" name="text1" class="query" value="hello" /> <input type="text" name="text2" class="query" value="word" /> <h3>密碼框</h3> <input type="password" name="password" class="query" value="123456" /> <h3>單選框</h3> 單選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" /> <h3>復(fù)選框</h3> 復(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/> <h3>search</h3> <input type="range" name="range" id="" class="query" value="" /> <input type="color" name="color" id="" class="query" value="" /> <h3> <button type="button" id="save"> 提交 </button> </h3>
4.此處引入了JQ庫。
4.1js代碼塊
使用說明:調(diào)用方法的時候傳入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);
});
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
跟我學(xué)習(xí)javascript的垃圾回收機(jī)制與內(nèi)存管理
跟我學(xué)習(xí)javascript的垃圾回收機(jī)制與內(nèi)存管理,感興趣的小伙伴們可以參考一下2015-11-11
js實(shí)現(xiàn)的xml對象轉(zhuǎn)json功能示例
這篇文章主要介紹了js實(shí)現(xiàn)的xml對象轉(zhuǎn)json功能,結(jié)合實(shí)例形式分析了javascript轉(zhuǎn)換成xml所涉及的字符串、對象、數(shù)組、遍歷等操作技巧與使用方法,需要的朋友可以參考下2016-12-12
Javascript實(shí)現(xiàn)飛動廣告效果的方法
這篇文章主要介紹了Javascript實(shí)現(xiàn)飛動廣告效果的方法,可實(shí)現(xiàn)廣告窗口的浮動顯示效果,且廣告窗口具有關(guān)閉功能,需要的朋友可以參考下2015-05-05
Java中int與integer的區(qū)別(基本數(shù)據(jù)類型與引用數(shù)據(jù)類型)
這篇文章主要介紹了int與integer的區(qū)別(基本數(shù)據(jù)類型與引用數(shù)據(jù)類型),簡單的說 int 是基本數(shù)據(jù)類型,integer 是引用數(shù)據(jù)類型,具體區(qū)別詳解大家參考下本文2017-02-02
js實(shí)現(xiàn)溫度計(jì)時間樣式代碼分享
本文主要介紹了javascript實(shí)現(xiàn)溫度計(jì)時間樣式,推薦給大家,有需要的小伙伴可以參考下。2015-08-08
bootstrapValidator.min.js表單驗(yàn)證插件
這篇文章主要為大家詳細(xì)介紹了bootstrapValidator.min.js表單驗(yàn)證插件的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-02-02

