当前位置: 移动技术网 > IT编程>开发语言>JavaScript > JS实现的文件拖拽上传功能示例

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

2018年05月29日  | 移动技术网IT编程  | 我要评论

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

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>www.jb51.net 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>

使用在线运行测试效果如下:

更多关于javascript相关内容感兴趣的读者可查看本站专题:《javascript表单(form)操作技巧大全》、《javascript查找算法技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》、《javascript错误与调试技巧总结》及《javascript数学运算用法总结

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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网