您好,登錄后才能下訂單哦!
小編給大家分享一下JavaScript怎么實(shí)現(xiàn)動(dòng)態(tài)添加Form表單元素的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
具體如下:
之前寫過類似的文章(如:javascript實(shí)現(xiàn)的動(dòng)態(tài)添加表單元素input,button等),現(xiàn)在看來比較初級(jí),弄一個(gè)高級(jí)的簡(jiǎn)單的
情景: 后臺(tái)要上傳游戲截圖,截圖數(shù)量不確定,因此使用動(dòng)態(tài)添加input節(jié)點(diǎn)的方法去實(shí)現(xiàn)這個(gè)效果
主要用到的函數(shù)有:
document.getElementById();
objNode.parentNode;
objNode.cloneNode();
objNode.removeAtrribute();
objNode.innerHTML();
objNode.appendChild();
html:
<div class="well well-sm"> <div class="form-group"> <label class="form-label">游戲截圖:</label> <input type="file" name="jietu[]" class="form-input"> <span class="form-tip" onclick="add_jietu()"><font color="#428bca">點(diǎn)擊添加游戲截圖</font></span> </div> <div class="form-group" id="add_jietu"> <label class="form-label">游戲截圖:</label> <input type="file" name="jietu[]" class="form-input"> </div> </div>
javascript:
<script type="text/javascript"> function add_jietu() { var add_jietu = document.getElementById('add_jietu'); var nodeFather = add_jietu.parentNode; var node_clone = add_jietu.cloneNode(); content = add_jietu.innerHTML; node_clone.removeAttribute('id'); node_clone.innerHTML = content; nodeFather.appendChild(node_clone); } </script>
注意:
1. js第6行使用的是"克隆節(jié)點(diǎn)"函數(shù),克隆后的節(jié)點(diǎn)里邊并沒有html,需要第9行的代碼去填充內(nèi)容
2. 使用克隆功能,因?yàn)樵摲椒ㄉ傻淖兞款愋褪?quot;節(jié)點(diǎn)類型", 才可以用到appendChild()函數(shù)里做參數(shù)
3. 節(jié)點(diǎn)的 nextSibling 和 lastChild 屬性得到的變量是 Text類型(在chrome的調(diào)試窗口中看到的)
以上是“JavaScript怎么實(shí)現(xiàn)動(dòng)態(tài)添加Form表單元素的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。