国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

Javascript表單序列化原理及實(shí)現(xiàn)代碼詳解

瀏覽:60日期:2023-10-09 18:48:31

隨著 Ajax 的出現(xiàn),表單序列化已經(jīng)成為一種常見需求。在 JavaScript 中,可 以利用表單字段的 type 屬性,連同 name 和 value 屬性一起實(shí)現(xiàn)對(duì)表單的序列化。在編寫代碼之前, 有必須先搞清楚在表單提交期間,瀏覽器是怎樣將數(shù)據(jù)發(fā)送給服務(wù)器的。

​1. 對(duì)表單字段的名稱和值進(jìn)行 URL 編碼,使用和號(hào)(&)分隔。

2. 不發(fā)送禁用的表單字段。

3. 只發(fā)送勾選的復(fù)選框和單選按鈕。

4. 不發(fā)送 type 為'reset'和'button'的按鈕。

5. 多選選擇框中的每個(gè)選中的值單獨(dú)一個(gè)條目。

6. 在單擊提交按鈕提交表單的情況下,也會(huì)發(fā)送提交按鈕;否則,不發(fā)送提交按鈕。

7. <select>元素的值,就是選中的<option>元素的 value 特性的值。如果<option>元素沒有 value 特性,則是<option>元素的文本值。

在表單序列化過程中,一般不包含任何按鈕字段,因?yàn)榻Y(jié)果字符串很可能是通過其他方式提交的。除此之外的其他上述規(guī)則都應(yīng)該遵循。

基本的表單序列化可以通過遍歷表單元素實(shí)現(xiàn),實(shí)例代碼如下:

function serialize(form){ var params = []; var eles = form.elements; for (var i = 0;i<ele.length;i++){ let field = ele[i]; switch(field.type){ case 'file': case 'submit': case 'reset': case 'button': break; case 'radio': case 'checkbox': if(!field.checked){ break; } default: //不包含沒有名字的表單字段 if (field.name.length){ parts.push(encodeURIComponent(field.name) + '=' + encodeURIComponent(field.value)); } } } return parts.join('&');}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 日韩二区三区 | 亚洲国产精品综合欧美 | 日本精品一区二区三区视频 | 俄罗斯美女毛片 | 91精品国产免费久久 | 成年女人毛片免费观看中文w | 亚洲国产日韩综合久久精品 | 神马三级我不卡 | 韩国一级理黄论片 | 国产男女在线观看 | 久久国产精品久久国产片 | 99精品视频一区在线视频免费观看 | 久久免费视频网 | 久久国产亚洲欧美日韩精品 | 九九九九精品视频在线播放 | 男女乱淫真视频免费观看 | 精品国产1区 | 欧美激情视频一区二区免费 | 91精品福利手机国产在线 | 亚洲成人性视频 | 国产成人精品高清不卡在线 | 日韩欧美一区二区三区不卡在线 | 国产精品久久久久久久免费 | 69精品免费视频 | 日韩毛片免费视频一级特黄 | 久久精品国产99久久6动漫欧 | 欧美成人自拍视频 | 97国产影院 | a高清免费毛片久久 | 老司机深夜影院入口aaaa | 亚洲人成一区二区三区 | 国产精品欧美一区二区三区 | 一级毛片大全 | 9久9久女女热精品视频免费观看 | 99久久精品国产自免费 | 免费一级毛片在线播放视频 | 国产高清视频a在线大全 | 成人久久免费视频 | 亚洲深夜 | 成人做爰视频www视频 | 在线观看国产欧美 |