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控制select的text/value值为选中状态
Jun 03 Javascript
jsonp跨域请求数据实现手机号码查询实例分析
Dec 12 Javascript
AngularJS使用ngOption实现下拉列表的实例代码
Jan 23 Javascript
Bootstrap每天必学之级联下拉菜单
Mar 27 Javascript
纯js代码制作的网页时钟特效【附实例】
Mar 30 Javascript
JavaScript数据操作_浅谈原始值和引用值的操作本质
Aug 23 Javascript
vue2.0 循环遍历加载不同图片的方法
Mar 06 Javascript
JavaScript中判断为整数的多种方式及保留两位小数的方法
Sep 09 Javascript
jQuery模仿ToDoList实现简单的待办事项列表
Dec 30 jQuery
vue中使用WX-JSSDK的两种方法(推荐)
Jan 18 Javascript
原生js实现五子棋游戏
May 28 Javascript
原生JavaScript实现随机点名表
Jan 14 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中文件缓存转内存缓存的方法
2011/12/06 PHP
ThinkPHP CURD方法之where方法详解
2014/06/18 PHP
PHP+APACHE实现网址伪静态
2015/02/22 PHP
Linux php 中文乱码的快速解决方法
2016/05/13 PHP
php版微信自定义回复功能示例
2016/12/05 PHP
PHP基于SimpleXML生成和解析xml的方法示例
2017/07/17 PHP
百度 popup.js 完美修正版非常的不错 脚本之家推荐
2009/04/17 Javascript
禁止js文件缓存的代码
2010/04/09 Javascript
js监控IE火狐浏览器关闭、刷新、回退、前进事件
2014/07/23 Javascript
使用Jquery实现每日签到功能
2015/04/03 Javascript
javascript实现确定和取消提示框效果
2015/07/10 Javascript
JavaScript笔记之数据属性和存储器属性
2016/03/31 Javascript
webpack入门必知必会
2017/01/16 Javascript
js 用于检测类数组对象的函数方法
2017/05/02 Javascript
Javascript实现从小到大的数组转换成二叉搜索树
2017/06/13 Javascript
vuejs实现标签选项卡动态更改css样式的方法
2018/05/31 Javascript
jQuery实现的简单获取索引功能示例
2018/06/04 jQuery
一文秒懂nodejs中的异步编程
2021/01/28 NodeJs
简单介绍Python的Tornado框架中的协程异步实现原理
2015/04/23 Python
对numpy中shape的深入理解
2018/06/15 Python
python编写简单端口扫描器
2019/09/04 Python
Python3和pyqt5实现控件数据动态显示方式
2019/12/13 Python
Python实现搜索算法的实例代码
2020/01/02 Python
Python autoescape标签用法解析
2020/01/17 Python
Python基于time模块表示时间常用方法
2020/06/18 Python
利用python查看数组中的所有元素是否相同
2021/01/08 Python
浅谈css3中的前缀
2016/07/20 HTML / CSS
HTML5实现经典坦克大战坦克乱走还能发出一个子弹
2013/09/02 HTML / CSS
应用英语专业自荐信
2014/01/26 职场文书
会展策划与管理专业大学生职业生涯规划
2014/02/07 职场文书
军训学生自我鉴定
2014/02/12 职场文书
揭牌仪式策划方案
2014/05/28 职场文书
2015大学自主招生自荐信范文
2015/03/04 职场文书
2015年幼儿园学前班工作总结
2015/05/18 职场文书
如何设计高效合理的MySQL查询语句
2021/05/26 MySQL
pytest实现多进程与多线程运行超好用的插件
2022/07/15 Python