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实现遮罩层效果原理分析
May 27 Javascript
浅谈javascript中的instanceof和typeof
Feb 27 Javascript
jQuery Validate插件实现表单强大的验证功能
Dec 18 Javascript
jQuery插件zTree实现的基本树与节点获取操作示例
Mar 08 Javascript
BootStrap的双日历时间控件使用
Jul 25 Javascript
echarts学习笔记之图表自适应问题详解
Nov 22 Javascript
vue中v-model的应用及使用详解
Jun 27 Javascript
Angular6封装http请求的步骤详解
Aug 13 Javascript
jQuery实现的简单拖拽功能示例【测试可用】
Aug 14 jQuery
解决VUE中document.body.scrollTop为0的问题
Sep 15 Javascript
Three.js中矩阵和向量的使用教程
Mar 19 Javascript
详解vue中在父组件点击按钮触发子组件的事件
Nov 13 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
关于文本留言本的分页代码
2006/10/09 PHP
PHP连接access数据库
2008/03/27 PHP
PHP define函数的使用说明
2008/08/27 PHP
使用PHP导出Word文档的原理和实例
2013/10/21 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(六)
2014/06/23 PHP
php把时间戳转换成多少时间之前函数的实例
2016/11/16 PHP
php使用mysqli和pdo扩展,测试对比连接mysql数据库的效率完整示例
2019/05/09 PHP
如何在PHP中使用数组
2020/06/09 PHP
javascript SocialHistory 检查访问者是否访问过某站点
2008/08/02 Javascript
javascript学习笔记(十一) 正则表达式介绍
2012/06/20 Javascript
通过JQuery实现win8一样酷炫的动态磁贴效果(示例代码)
2013/07/13 Javascript
jQuery中$.fn的用法示例介绍
2013/11/05 Javascript
IE6-IE9中tbody的innerHTML不能赋值的解决方法
2014/06/05 Javascript
javascript中if和switch,==和===详解
2015/07/30 Javascript
深入浅析JavaScript函数前面的加号和叹号
2016/07/09 Javascript
微信小程序 Button 组件详解及简单实例
2017/01/10 Javascript
vue父组件向子组件(props)传递数据的方法
2018/01/02 Javascript
layui 给数据表格加序号的方法
2018/08/20 Javascript
vue初始化动画加载的实例
2018/09/01 Javascript
js实现轮播图特效
2020/05/28 Javascript
JavaScript文档加载模式以及元素获取
2020/07/28 Javascript
vue 实现基础组件的自动化全局注册
2020/12/25 Vue.js
[03:21]辉夜杯主赛事 12月25日TOP5
2015/12/26 DOTA
Python日期操作学习笔记
2008/10/07 Python
Python中__call__用法实例
2014/08/29 Python
python中的lambda表达式用法详解
2016/06/22 Python
Django中的用户身份验证示例详解
2019/08/07 Python
关于tf.TFRecordReader()函数的用法解析
2020/02/17 Python
从python读取sql的实例方法
2020/07/21 Python
Python 通过正则表达式快速获取电影的下载地址
2020/08/17 Python
Python抖音快手代码舞(字符舞)的实现方法
2021/02/07 Python
Smallable英国家庭概念店:设计师童装及家居装饰
2017/07/05 全球购物
支部组织生活会方案
2014/06/10 职场文书
机关保密工作承诺书
2015/05/04 职场文书
python工具dtreeviz决策树可视化和模型可解释性
2022/03/03 Python
动视暴雪取消疫苗禁令 让所有员工返回线下工作
2022/04/03 其他游戏