JS实现的文件拖拽上传功能示例


Posted in Javascript onMay 21, 2018

本文实例讲述了JS实现的文件拖拽上传功能。分享给大家供大家参考,具体如下:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>3water.com JS文件拖拽上传</title>
<style>
div{
 width: 300px;
 height: 300px;
 border:1px dashed #000;
 position:absolute;
 top: 50%;
 left: 50%;
 margin:-150px 0 0 -150px;
 text-align:center;
 font:20px/300px '微软雅黑';
 display:none;
}
</style>
<script>
 window.onload = function () {
  var oBox = document.getElementById('box');
  var oM = document.getElementById('m1');
  var timer = null;
  document.ondragover = function(){
   clearTimeout(timer);
   timer = setTimeout(function(){
    oBox.style.display = 'none';
   },200);
   oBox.style.display = 'block';
  };
  //进入子集的时候 会触发ondragover 频繁触发 不给ondrop机会
  oBox.ondragenter = function(){
   oBox.innerHTML = '请释放鼠标';
  };
  oBox.ondragover = function(){
   return false;
  };
  oBox.ondragleave = function(){
   oBox.innerHTML = '请将文件拖拽到此区域';
  };
  oBox.ondrop = function(ev){
   var oFile = ev.dataTransfer.files[0];
   var reader = new FileReader();
   //读取成功
   reader.onload = function(){
    console.log(reader);
   };
   reader.onloadstart = function(){
    alert('读取开始');
   };
   reader.onloadend = function(){
    alert('读取结束');
   };
   reader.onabort = function(){
    alert('中断');
   };
   reader.onerror = function(){
    alert('读取失败');
   };
   reader.onprogress = function(ev){
    var scale = ev.loaded/ev.total;
    if(scale>=0.5){
     alert(1);
     reader.abort();
    }
    oM.value = scale*100;
   };
   reader.readAsDataURL(oFile,'base64');
   return false;
  };
 };
</script>
</head>
<body>
<meter id="m1" value="0" min="0" max="100"></meter>
 <div id="box">请将文件拖拽到此区域</div>
</body>
</html>

使用http://tools.3water.com/code/HtmlJsRun在线运行测试效果如下:

JS实现的文件拖拽上传功能示例

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JavaScript获得选中文本内容的方法
Dec 02 Javascript
js给onclick事件赋值,动态传参数实例解说
Mar 28 Javascript
jQuery对象与DOM对象之间的相互转换
Mar 03 Javascript
javascript跑马灯抽奖实例讲解
Apr 17 Javascript
jquery实现上传文件大小类型的验证例子(推荐)
Jun 25 Javascript
原生javascript实现读写CSS样式的方法详解
Feb 20 Javascript
微信小程序--onShareAppMessage分享参数用处(页面分享)
Apr 18 Javascript
angularjs实现天气预报功能
Jun 16 Javascript
vue2.0 datepicker使用方法
Feb 04 Javascript
解决layer.msg 不居中 ifram中的问题
Sep 05 Javascript
微信小程序 轮播图实现原理及优化详解
Sep 29 Javascript
vue路由切换时取消之前的所有请求操作
Sep 01 Javascript
以v-model与promise两种方式实现vue弹窗组件
May 21 #Javascript
Vue二次封装axios为插件使用详解
May 21 #Javascript
详解vue的diff算法原理
May 20 #Javascript
详解使用vue-admin-template的优化历程
May 20 #Javascript
vuex进阶知识点巩固
May 20 #Javascript
简单的三步vuex入门
May 20 #Javascript
vue项目如何刷新当前页面的方法
May 18 #Javascript
You might like
php中++i 与 i++ 的区别
2012/08/08 PHP
深入mysql_fetch_row()与mysql_fetch_array()的区别详解
2013/06/05 PHP
PHP FTP操作类代码( 上传、拷贝、移动、删除文件/创建目录)
2014/05/10 PHP
ThinkPHP3.1新特性之对页面压缩输出的支持
2014/06/19 PHP
PHP实现的比较完善的购物车类
2014/12/02 PHP
PHP的Laravel框架中使用消息队列queue及异步队列的方法
2016/03/21 PHP
详谈php中 strtr 和 str_replace 的效率问题
2017/05/14 PHP
javascript 带有滚动条的表格,标题固定,带排序功能.
2009/11/13 Javascript
20款超赞的jQuery插件 Web开发人员必备
2011/02/26 Javascript
关于scrollLeft,scrollTop的浏览器兼容性测试
2013/03/19 Javascript
js关闭父窗口时关闭子窗口
2013/04/01 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(一)
2016/05/17 Javascript
总结几道关于Node.js的面试问题
2017/01/11 Javascript
浅谈jQuery中事情的动态绑定
2017/02/12 Javascript
ES6入门教程之Class和Module详解
2017/05/17 Javascript
webpack实现热加载自动刷新的方法
2017/07/30 Javascript
Vue.js 中的 v-show 指令及用法详解
2018/11/19 Javascript
JS事件流与事件处理程序实例分析
2019/08/16 Javascript
vue中全局路由守卫中替代this操作(this.$store/this.$vux)
2020/07/24 Javascript
python实现simhash算法实例
2014/04/25 Python
python使用mysql数据库示例代码
2017/05/21 Python
python读取一个目录下所有txt里面的内容方法
2018/06/23 Python
numpy.linspace 生成等差数组的方法
2018/07/02 Python
Pytorch 定义MyDatasets实现多通道分别输入不同数据方式
2020/01/15 Python
树莓派升级python的具体步骤
2020/07/05 Python
Django通过设置CORS解决跨域问题
2020/11/26 Python
英国羊绒服装购物网站:Pure Collection
2018/10/22 全球购物
Christys’ Hats官网:英国帽子制造商
2018/11/28 全球购物
Linux的文件类型
2016/07/05 面试题
2014年五四青年节活动方案
2014/03/29 职场文书
二年级班级文化建设方案
2014/05/10 职场文书
经济贸易专业自荐信
2014/06/11 职场文书
超市工作总结范文2014
2014/12/19 职场文书
倡议书格式及范文
2015/04/29 职场文书
Python数据可视化之绘制柱状图和条形图
2021/05/25 Python
根德5570型九灯四波段立体声收音机是电子管收音机的楷模 ? 再论5570
2022/04/05 无线电