js实现上传文件添加和删除文件选择框


Posted in Javascript onOctober 24, 2016

本文这里给大家说个用javascript实现的很实用的功能,是在上传附件的时候,可以动态地添加和删除文件选择框,然后一次性上传。

从理论上看,实现起来比较容易,但实际工作的时候还是遇到两个难点,这些难点归结起来都是一个原因造成的,那就是浏览器的兼容性。在脚本中要用到两个函数:insertAdjacentHTML和removeChild,而恰好这两个函数在Firefox下都不能正常使用。几乎花费了一天的时候,在网上搜索着解决的方法,还好被找到了,也让我大松一口气。

具体两个函数是这样的:

<script type="text/javascript">
  //删除文件选择框
  function removeFile(id) {
    var new_tr = id.parentNode;
    try {
      //new_tr.removeNode(true);
      // just ie , not w3c;

      // other idea
      var tmp = new_tr.parentNode;
      // 为了在ie和firefox下都能正常使用,就要用另一个方法代替,最取上一层的父结点,然后remove.
      tmp.removeChild(new_tr);

     } catch(e) {}
  }
  
  //添加文件选择框
  function addFile(id)
  {
   var str = '<div><input type="file" runat="server" name="file" onKeyDown="this.blur();" oncontextmenu="return false" /><input type="button" value="删除" style="height:22px;" onclick="removeFile(this)" /></div>'
   insertHtml("beforeend",document.getElementById(id),str);
   }
</script>

页面上这样引用:

<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框的内容>

第二个案例

文件上传,删除效果图:

刚开始:

js实现上传文件添加和删除文件选择框

点击按钮“选择更多后”,可以添加很多选择文件:

js实现上传文件添加和删除文件选择框

点击按钮“删除”后:

js实现上传文件添加和删除文件选择框

实现代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>选择文件</title>
<style type="text/css">
*{
margin:0px;
padding:0px;
}
div{
margin:10px;
}
</style>


<script>
//当点击添加更多时,增加一个DIV
//先增加两个input

function 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>

代码瑕疵:!!!!在删除函数中,我选择的是删除第一个元素节点,而不是真正意义上的删除当前按钮,不知道怎么改善,求改正。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery学习笔记之Helloworld
Dec 22 Javascript
JS 排序输出实现table行号自增前端动态生成的tr
Aug 13 Javascript
js实现遮罩层弹出框的方法
Jan 15 Javascript
Backbone.js 0.9.2 源码注释中文翻译版
Jun 25 Javascript
javascript动画算法实例分析
Jul 31 Javascript
jquery+html5烂漫爱心表白动画代码分享
Aug 24 Javascript
JavaScript调试的多个必备小Tips
Jan 15 Javascript
Bootstrap面板使用方法
Jan 16 Javascript
jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法
Mar 08 Javascript
JS实现浏览上传文件的代码
Aug 23 Javascript
原生JavaScript实现remove()和recover()功能示例
Jul 24 Javascript
vue+VeeValidate 校验范围实例详解(部分校验,全部校验)
Oct 19 Javascript
JS取数字小数点后两位或n位的简单方法
Oct 24 #Javascript
第一次接触Bootstrap框架
Oct 24 #Javascript
Node.js Sequelize如何实现数据库的读写分离
Oct 23 #Javascript
JavaScript数组去重的几种方法效率测试
Oct 23 #Javascript
Javascript 实现简单计算器实例代码
Oct 23 #Javascript
JavaScript页面实时显示当前时间实例代码
Oct 23 #Javascript
jquery 实现回车登录详解及实例代码
Oct 23 #Javascript
You might like
PHP 程序员应该使用的10个组件
2009/10/31 PHP
深入PHP许愿墙模块功能分析
2013/06/25 PHP
基于PHP实现等比压缩图片大小
2016/03/04 PHP
php中file_get_contents()函数用法实例
2019/02/21 PHP
PHP 计算两个时间段之间交集的天数示例
2019/10/24 PHP
利用javascript查看html源文件
2006/11/08 Javascript
关于递归运算的顺序测试代码
2011/11/30 Javascript
javascript实现数独解法
2015/03/14 Javascript
JavaScript通过prototype给对象定义属性用法实例
2015/03/23 Javascript
JavaScript生成SQL查询表单的方法
2015/08/13 Javascript
js实现漫天星星效果
2017/01/19 Javascript
浅谈JavaScript异步编程
2017/01/20 Javascript
Bootstrap表单简单实现代码
2017/03/06 Javascript
利用jqprint插件打印页面内容的实现方法
2018/01/09 Javascript
vue项目中应用ueditor自定义上传按钮功能
2018/04/27 Javascript
JQuery模拟实现网页中自定义鼠标右键菜单功能
2018/11/14 jQuery
vue中组件的过渡动画及实现代码
2018/11/21 Javascript
详解webpack 最简打包结果分析
2019/02/20 Javascript
微信小程序城市选择及搜索功能的方法
2019/03/22 Javascript
Vue3项目打包后部署到服务器 请求不到后台接口解决方法
2020/02/06 Javascript
antd-日历组件,前后禁止选择,只能选中间一部分的实例
2020/10/29 Javascript
[04:03][TI9趣味短片] 小鸽子茶话会
2019/08/20 DOTA
python 3.6 tkinter+urllib+json实现火车车次信息查询功能
2017/12/20 Python
python检测IP地址变化并触发事件
2018/12/26 Python
在Qt中正确的设置窗体的背景图片的几种方法总结
2019/06/19 Python
基于sklearn实现Bagging算法(python)
2019/07/11 Python
蹦床仓库:Trampoline Warehouse
2018/12/06 全球购物
Mamaearth官方网站:印度母婴护理产品公司
2019/10/06 全球购物
自我鉴定200字
2013/10/28 职场文书
制药工程专业个人求职自荐信
2014/01/25 职场文书
银行职员个人的工作自我评价
2014/02/15 职场文书
数学检讨书1000字
2014/02/24 职场文书
电子商务专业应届毕业生求职信
2014/06/21 职场文书
学雷锋活动总结报告
2014/06/26 职场文书
党员民主生活会对照检查材料思想汇报
2014/09/28 职场文书
长城的导游词
2015/01/30 职场文书