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 相关文章推荐
JS类中定义原型方法的两种实现的区别
Mar 08 Javascript
JavaScript 以对象为索引的关联数组
May 19 Javascript
JavaScript面向对象(极简主义法minimalist approach)
Jul 17 Javascript
JS实现获取剪贴板内容的方法
Jun 21 Javascript
浅谈JS正则表达式的RegExp对象和括号的使用
Jul 28 Javascript
Angular 中 select指令用法详解
Sep 29 Javascript
javascript实现获取指定精度的上传文件的大小简单实例
Oct 25 Javascript
jQuery 选择符详细介绍及整理
Dec 02 Javascript
react-native 封装选择弹出框示例(试用ios&amp;android)
Jul 11 Javascript
js字符串倒序的实例代码
Nov 30 Javascript
前端面试知识点目录一览
Apr 15 Javascript
Element实现表格分页数据选择+全选所有完善批量操作
Jun 07 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解析xml 的四种简单方法(附实例)
2016/07/11 PHP
php微信公众平台开发之微信群发信息
2016/09/13 PHP
php生出随机字符串
2017/07/06 PHP
在IE中调用javascript打开Excel的代码(downmoon原作)
2007/04/02 Javascript
又一个小巧的图片预加载类
2007/05/05 Javascript
国外Lightbox v2.03.3 最新版 下载
2007/10/17 Javascript
javascript 火狐(firefox)不显示本地图片问题解决
2008/07/05 Javascript
Jquery中ajax方法data参数的用法小结
2014/02/12 Javascript
jQuery实用技巧必备(上)
2015/11/02 Javascript
Three.js学习之几何形状
2016/08/01 Javascript
fullCalendar中文API官方文档
2017/02/07 Javascript
教你用Cordova打包Vue项目的方法
2017/10/17 Javascript
Vue-router的使用和出现空白页,路由对象属性详解
2018/09/03 Javascript
在vue中解决提示警告 for循环报错的方法
2018/09/28 Javascript
vue-router传递参数的几种方式实例详解
2018/11/13 Javascript
Fundebug支持监控微信小程序HTTP请求错误的方法
2019/02/21 Javascript
解决vue打包后vendor.js文件过大问题
2019/07/03 Javascript
ES6 Iterator接口和for...of循环用法分析
2019/07/31 Javascript
JS快速实现简单计算器
2020/04/08 Javascript
[02:40]DOTA2英雄基础教程 炼金术士
2013/12/23 DOTA
Python translator使用实例
2008/09/06 Python
python函数返回多个值的示例方法
2013/12/04 Python
Python操作MySQL数据库的方法
2018/06/20 Python
Python中的取模运算方法
2018/11/10 Python
Python直接赋值、浅拷贝与深度拷贝实例分析
2019/06/18 Python
Window系统下Python如何安装OpenCV库
2020/03/05 Python
Python如何生成xml文件
2020/06/04 Python
Python csv文件记录流程代码解析
2020/07/16 Python
装上这 14 个插件后,PyCharm 真的是无敌的存在
2021/01/11 Python
什么是抽象
2015/12/13 面试题
英文求职信范文
2014/05/23 职场文书
宣传工作经验材料
2014/06/02 职场文书
公安局负责人查摆问题及整改方案
2014/09/27 职场文书
演讲开场白台词大全
2015/05/29 职场文书
2015年重阳节活动主持词
2015/07/30 职场文书
《珍珠鸟》教学反思
2016/02/16 职场文书