将外部文件拖拽到浏览器中预览

这篇博客介绍如何利用JavaScript实现将外部文件拖拽到浏览器中预览的功能。通过监听拖拽事件,读取文件内容,并根据文件类型如图片(JPEG)或其他文本类型进行不同的处理,最终在页面上展示预览内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script src="图片拖放/lib.js"></script>
</head>
<style>
#dropbox{
width:800px;
height: 100px;
background: papayawhip;
text-align: center;
font-size: 30px;
}
ul{
background: paleturquoise;
width:800px;
height: 500px;
}
ul li{
width: 200px;
height: 200px;
margin-top: 10px;
border: 2px dashed palevioletred;
list-style: none;
float: left;
overflow: hidden;
}
ul li img{
width: 300px;
height: 300px;
}
</style>
<body>

<div id="dropbox" draggable="true">将文件拖到此区域 </div>  
    <ul id="filecontent" draggable="true"></ul>  
    <script>  
      var dropbox = document.getElementById("dropbox"); 
      //拖离
      document.addEventListener("dragleave", function(e){
      yc.stopEvent(e);
      }, false);
      //拖进
      document.addEventListener("dragenter", function(e){
      yc.stopEvent(e);
      }, false);
      //拖来拖去
       document.addEventListener("dragover", function(e){
      yc.stopEvent(e);
      }, false);
      //拖后放
      document.addEventListener("drop", function(e){
      yc.stopEvent(e); 
      }, false);
 
    
    var box = document.getElementById('dropbox'); //拖拽区域 
    box.addEventListener("drop",function(e){ 
        yc.stopEvent(e); //取消默认浏览器拖拽效果 
        var files = e.dataTransfer.files; //获取文件对象 
        //检测是否是拖拽文件到页面的操作 
        if(files.length == 0){return false;} 
        
       for(var i=0;i<files.length;i++){
if(files){
//实例化FileReader()对象    readAsText   readAsBineryString  readAsArrayBuffer
var reader=new FileReader();
//alert(files[i].type);
switch(files[i].type){
case "text/plain":
reader.readAsText(files[i]);
break;
case "BineryString":
reader.readAsBineryString(files[i]);
break;
case "ArrayBuffer":
reader.readAsArrayBuffer(files[i]);
break;
case "image/jpeg":
reader.readAsDataURL(files[i]);   
break;
}
}
//存放选择的文件
reader.onload=function(){
var result=this.result;
if((files[0].type)== ("image/jpeg")  ){
var filecontent=document.getElementById("filecontent");
var li=document.createElement("li");
li.innerHTML+="<img src='"+result+"' />";
filecontent.appendChild(li);
}else{
var filecontent=document.getElementById("filecontent");
var li=document.createElement("li");
li.innerHTML+=result;
filecontent.appendChild(li);
}
}
}
    },false); 

    
    </script>  
</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值