JavaScript实现动态添加Form表单元素的方法示例
本文实例讲述了javascript实现动态添加form表单元素的方法。分享给大家供大家参考,具体如下:
之前写过类似的文章(如:),现在看来比较初级,弄一个高级的简单的
情景: 后台要上传游戏截图,截图数量不确定,因此使用动态添加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>
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行使用的是"克隆节点"函数,克隆后的节点里边并没有html,需要第9行的代码去填充内容
2. 使用克隆功能,因为该方法生成的变量类型是"节点类型", 才可以用到appendchild()函数里做参数
3. 节点的 nextsibling 和 lastchild 属性得到的变量是 text类型(在chrome的调试窗口中看到的)
更多关于javascript相关内容感兴趣的读者可查看本站专题:《javascript表单(form)操作技巧大全》、《javascript操作dom技巧总结》、《javascript数组操作技巧总结》、《javascript数学运算用法总结》、《javascript数据结构与算法技巧总结》及《javascript错误与调试技巧总结》
希望本文所述对大家javascript程序设计有所帮助。
上一篇: vue如何获取点击事件源的方法
下一篇: 你知道蛋白质丰富的食物有哪些吗?