首页 > 代码库 > javascript动态添加form表单元素
javascript动态添加form表单元素
2014年11月7日 17:10:40
之前写过几篇类似的文章,现在看来比较初级,弄一个高级的简单的
情景: 后台要上传游戏截图,截图数量不确定,因此使用动态添加input节点的方法去实现这个效果
主要用到的函数有:
document.getElementById();
objNode.parentNode;
objNode.cloneNode();
objNode.removeAtrribute();
objNode.innerHTML();
objNode.appendChild();
html:
1 <div class="well well-sm"> 2 <div class="form-group"> 3 <label class="form-label">游戏截图:</label> 4 <input type="file" name="jietu[]" class="form-input"> 5 <span class="form-tip" onclick="add_jietu()"><font color="#428bca">点击添加游戏截图</font></span> 6 </div> 7 <div class="form-group" id="add_jietu"> 8 <label class="form-label">游戏截图:</label> 9 <input type="file" name="jietu[]" class="form-input">10 </div>11 </div>
javascript:
1 <script type="text/javascript"> 2 function add_jietu() 3 { 4 var add_jietu = document.getElementById(‘add_jietu‘); 5 var nodeFather = add_jietu.parentNode; 6 var node_clone = add_jietu.cloneNode(); 7 content = add_jietu.innerHTML; 8 node_clone.removeAttribute(‘id‘); 9 node_clone.innerHTML = content;10 nodeFather.appendChild(node_clone);11 }12 </script>
注意:
1. js第6行使用的是"克隆节点"函数,克隆后的节点里边并没有html,需要第9行的代码去填充内容
2. 使用克隆功能,因为该方法生成的变量类型是"节点类型", 才可以用到appendChild()函数里做参数
3. 节点的 nextSibling 和 lastChild 属性得到的变量是 Text类型(在chrome的调试窗口中看到的)
javascript动态添加form表单元素
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。