這篇文章主要介紹了serializeArray()方法怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
.serializeArray()方法使用標準的W3C"successful controls"的標準來檢測哪些元素應當包括在內。被禁用的元素不會被包括在內。并且,元素必須含有 name 屬性。此外,提交按鈕的值也不會被序列化。文件選擇元素的數據也不會被序列化。
.serializeArray() 方法可以對單獨選擇的表單元素對象進行操作, 比如 <input>, <textarea>, 和 <select>。還有個更方便的方法是,直接使用 <form> 標簽來進行序列化操作:
$('form').submit(function() {
console.log($(this).serializeArray());
return false;
});
這將產生以下數據結構(瀏覽器提供的console.log):
[
{
name: "a",
value: "1"
},
{
name: "b",
value: "2"
},
{
name: "c",
value: "3"
},
{
name: "d",
value: "4"
},
{
name: "e",
value: "5"
}
]
例子:
從表單獲取值,遍歷并且顯示他們
<!DOCTYPE html>
<html>
<head>
<style>
body, select { font-size:14px; }
form { margin:5px; }
p { color:red; margin:5px; }
b { color:blue; }
</style>
<script src="https://code.jquery.com/jquery-latest.js"></script>
</head>
<body>
<p><b>Results:</b> <span id="results"></span></p>
<form>
<select name="single">
<option>Single</option>
<option>Single2</option>
</select>
<select name="multiple" multiple="multiple">
<option selected="selected">Multiple</option>
<option>Multiple2</option>
<option selected="selected">Multiple3</option>
</select><br/>
<input type="checkbox" name="check" value="check1" id="ch2"/>
<label for="ch2">check1</label>
<input type="checkbox" name="check" value="check2" checked="checked" id="ch3"/>
<label for="ch3">check2</label>
<input type="radio" name="radio" value="radio1" checked="checked" id="r1"/>
<label for="r1">radio1</label>
<input type="radio" name="radio" value="radio2" id="r2"/>
<label for="r2">radio2</label>
</form>
<script>
function showValues() {
var fields = $(":input").serializeArray();
$("#results").empty();
jQuery.each(fields, function(i, field){
$("#results").append(field.value + " ");
});
}
$(":checkbox, :radio").click(showValues);
$("select").change(showValues);
showValues();
</script>
</body>
</html>
感謝你能夠認真閱讀完這篇文章,希望小編分享的“serializeArray()方法怎么用”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。