时间:2021-05-26
本文这里给大家说个用javascript实现的很实用的功能,是在上传附件的时候,可以动态地添加和删除文件选择框,然后一次性上传。
从理论上看,实现起来比较容易,但实际工作的时候还是遇到两个难点,这些难点归结起来都是一个原因造成的,那就是浏览器的兼容性。在脚本中要用到两个函数:insertAdjacentHTML和removeChild,而恰好这两个函数在Firefox下都不能正常使用。几乎花费了一天的时候,在网上搜索着解决的方法,还好被找到了,也让我大松一口气。
具体两个函数是这样的:
页面上这样引用:
<div> <input type="button" value="添加附件(Add)" onclick="addFile('myfile')"> </div> <div id="myfile"></div>在addFile函数中引用了另一个函数:insertHtml,这个函数主要是针对insertAdjacentHTML在firefox下无效的情况重写的,具体可以通过搜索insertAdjacentHTML找到。
PS:清除file框的内容
<input type=file name=ttt> <input type=button onclick="ttt.select();document.execCommand('Delete');" value=清除file框的内容>第二个案例
文件上传,删除效果图:
刚开始:
点击按钮“选择更多后”,可以添加很多选择文件:
点击按钮“删除”后:
实现代码:
<!DOCTYPE html><html><head><meta charset="utf-8"><title>选择文件</title><style type="text/css">*{margin:0px;padding:0px;}div{margin:10px;}</style><script>//当点击添加更多时,增加一个DIV//先增加两个inputfunction addFile(){var fragment=document.createDocumentFragment();var divNode=document.getElementById("container");var newDiv=document.createElement("div");newDiv.setAttribute("id","file");fragment.appendChild(newDiv);var newInput=document.createElement("input");newInput.setAttribute("type","file");newInput.setAttribute("name","选择文件");newDiv.appendChild(newInput);var newInput=document.createElement("input");newInput.setAttribute("type","button");newInput.setAttribute("value","删除");newInput.setAttribute("onclick","delFile()");newInput.setAttribute("id","1");newDiv.appendChild(newInput);divNode.appendChild(fragment);}function delFile(){var divNode=document.getElementById("container");divNode.removeChild(divNode.firstElementChild);}</script></head><body><input type="button" value="选择更多" onclick="addFile()"/><div id="container"><div id="file"><input type="file" name="选择文件"/><input type="button" value="删除" onclick="delFile()" /></div></div></body></html>代码瑕疵:!!!!在删除函数中,我选择的是删除第一个元素节点,而不是真正意义上的删除当前按钮,不知道怎么改善,求改正。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
发邮件是需要添加一些文件,每添加一个文件,页面上可以显示一个表单文件上传选项。此功能为:初始时刻只有一个添加按钮,当点击添加文件时,会增加一个选择文件和删除区域
本文实例为大家分享了JSStruts2多文件上传的具体代码,供大家参考,具体内容如下1、JSP页面:JS控制增加删除多个上传文件框,代码如下: 序号文
Javascriptajax实现获取文件大小的方法。顾名思义,通过JS和Ajax来获取上传文件的大小,在上传之前可以有个判断,对上传的文件有所控制,因为js控制
考虑一个常见的用户上传头像的场景:点击按钮,弹出文件选择框选中图片并确认后直接上传图片实现这个功能,需要使用来添加文件,并实现上传功能。传统的上传文件是将放到中
js实现获取指定精度的上传文件的大小,主要采用html和JavaScript,用浏览器运行下述代码,按照操作:选择文件->获得文件大小的顺序,即可。源码:获得文