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 相关文章推荐
javascript的事件描述
Sep 08 Javascript
JsDom 编程小结
Aug 09 Javascript
jquery-syntax动态语法着色示例代码
May 14 Javascript
JQuery自动触发事件的方法
Jun 13 Javascript
javascript实现label标签跳出循环操作
Mar 06 Javascript
js中遍历Map对象的简单实例
Aug 08 Javascript
实例解析Array和String方法
Dec 14 Javascript
AngularJS实践之使用ng-repeat中$index的注意点
Dec 22 Javascript
JavaScript使用FileReader实现图片上传预览效果
Mar 27 Javascript
JS中验证整数和小数的正则表达式
Oct 08 Javascript
小程序自定义导航栏兼容适配所有机型(附完整案例)
Apr 26 Javascript
微信小程序开发打开另一个小程序的实现方法
May 17 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
星际RPG字典
2020/03/04 星际争霸
计算2000年01月01日起到指定日的天数
2006/10/09 PHP
php删除与复制文件夹及其文件夹下所有文件的实现代码
2013/01/23 PHP
CI框架中数据库操作函数$this-&gt;db-&gt;where()相关用法总结
2016/05/17 PHP
PHP获取input输入框中的值去数据库比较显示出来
2016/11/16 PHP
jquery 页面全选框实践代码
2010/04/02 Javascript
TextArea不支持maxlength的解决办法(jquery)
2011/09/13 Javascript
查找Oracle高消耗语句的方法
2014/03/22 Javascript
JavaScript中的类与实例实现方法
2015/01/23 Javascript
纯css下拉菜单 无需js
2016/08/15 Javascript
微信开发 JS-SDK 6.0.2 经常遇到问题总结
2016/12/08 Javascript
AngularJS 文件上传控件 ng-file-upload详解
2017/01/13 Javascript
函数四种调用模式以及其中的this指向
2017/01/16 Javascript
React进阶学习之组件的解耦之道
2017/08/07 Javascript
JS实现数组去重及数组内对象去重功能示例
2019/02/02 Javascript
vue组件定义,全局、局部组件,配合模板及动态组件功能示例
2019/03/19 Javascript
vue父组件触发事件改变子组件的值的方法实例详解
2019/05/07 Javascript
Python Nose框架编写测试用例方法
2017/10/26 Python
如何在VSCode上轻松舒适的配置Python的方法步骤
2019/10/28 Python
利用python实现冒泡排序算法实例代码
2019/12/01 Python
在 Pycharm 安装使用black的方法详解
2020/04/02 Python
解决python3.x安装numpy成功但import出错的问题
2020/11/17 Python
新加坡航空官方网站:Singapore Airlines
2016/10/13 全球购物
Cinque网上商店:德国服装品牌
2019/03/17 全球购物
乡下人家教学反思
2014/02/01 职场文书
教师求职信
2014/06/17 职场文书
2014年财务部工作总结
2014/11/11 职场文书
第二次离婚起诉书
2015/05/18 职场文书
工作年限证明模板
2015/06/15 职场文书
志愿服务心得体会
2016/01/15 职场文书
2019大学生社会实践报告汇总
2019/08/16 职场文书
祝福语集锦:送给闺蜜的生日祝福语
2019/10/08 职场文书
微信小程序实现录音Record功能
2021/05/09 Javascript
Python爬虫基础讲解之请求
2021/05/13 Python
只用Python就可以制作的简单词云
2021/06/07 Python
图文详解Nginx版本平滑升级方案
2021/09/15 Servers