在前端开发项目中,对表单的操作非常多,所以我们必须熟练掌握表单的常规应用,今天小编介绍一个表单的应用:如何实现动态添加Form表单元素。OK,废话不多说,走起。
情景: 后台要上传游戏截图,截图数量不确定,因此使用动态添加input节点的方法去实现这个效果
主要用到的函数有:
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">点击添加游戏截图</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>
JS
<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行使用的是"克隆节点"函数,克隆后的节点里边并没有html,需要第9行的代码去填充内容
2. 使用克隆功能,因为该方法生成的变量类型是"节点类型", 才可以用到appendChild()函数里做参数
3. 节点的 nextSibling 和 lastChild 属性得到的变量是 Text类型(在chrome的调试窗口中看到的)
大家可以去试试。
网友评论文明上网理性发言 已有0人参与
发表评论: