本文實(shí)例講述了JavaScript實(shí)現(xiàn)動態(tài)添加Form表單元素的方法。分享給大家供大家參考,具體如下:
之前寫過類似的文章(如:javascript實(shí)現(xiàn)的動態(tài)添加表單元素input,button等),現(xiàn)在看來比較初級,弄一個(gè)高級的簡單的
情景: 后臺要上傳游戲截圖,截圖數(shù)量不確定,因此使用動態(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)樵摲椒ㄉ傻淖兞款愋褪?節(jié)點(diǎn)類型", 才可以用到appendChild()函數(shù)里做參數(shù)
3. 節(jié)點(diǎn)的 nextSibling 和 lastChild 屬性得到的變量是 Text類型(在chrome的調(diào)試窗口中看到的)
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript表單(form)操作技巧大全》、《JavaScript操作DOM技巧總結(jié)》、《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答