小編給大家分享一下H5實現拖拉上傳文件的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創新互聯建站專注為客戶提供全方位的互聯網綜合服務,包含不限于成都網站設計、網站建設、新安網絡推廣、小程序制作、新安網絡營銷、新安企業策劃、新安品牌公關、搜索引擎seo、人物專訪、企業宣傳片、企業代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;創新互聯建站為所有大學生創業者提供新安建站搭建服務,24小時服務熱線:18982081108,官方網址:www.yijiale78.com
在HTML5的pc上面實現了相當多的功能,工作中也用到了拖拉上傳,特地記錄下該功能
在拖動目標上觸發事件 (源元素):
ondragstart - 用戶開始拖動元素時觸發
ondrag - 元素正在拖動時觸發
ondragend - 用戶完成元素拖動后觸發
釋放目標時觸發的事件:
ondragenter - 當被鼠標拖動的對象進入其容器范圍內時觸發此事件
ondragover - 當某被拖動的對象在另一對象容器范圍內拖動時觸發此事件
ondragleave - 當被鼠標拖動的對象離開其容器范圍內時觸發此事件
ondrop - 在一個拖動過程中,釋放鼠標鍵時觸發此事件
上代碼
<html lang="en">
<head>
<meta charset="UTF-8">
<title>拖拽</title>
<style>
.box{width:800px;height:600px;float:left;}
#box1{background-color:#ccc;}
#box2{background-color:#000;}
</style>
</head>
<body>
<p id="box1" class="box"></p>
<p id="box2" class="box"></p>
<img id="img1" src="1.jpg">
<p id="msg"></p>
</body>
<script>
var box1p,box2p,msgp,img1;
window.onload = function(){
box1p = document.getElementById('box1');
box2p = document.getElementById('box2');
msgp = document.getElementById('msg');
img1 = document.getElementById('img1');
box1p.ondragover = function(e){e.preventDefault();}
box2p.ondragover = function(e){e.preventDefault();}
img1.ondragstart = function(e){e.dataTransfer.setData('imgId','img1');}
box1p.ondrop = dropImghandler;
box2p.ondrop = dropImghandler;
}
function dropImghandler(e){
showObj(e);//獲取拖放所有信息
showObj(e.dataTransfer);//獲取文件
e.preventDefault();
var img = document.getElementById(e.dataTransfer.getData('imgId'));
e.target.appendChild(img);
}
function showObj(obj){
var s = '';
for(var k in obj){s += k+":"+obj[k]+"<br/>";}
msgp.innerHTML = s;
}
</script>
</html>該功能是可以將圖片拖拉到左右兩個p中的方法,我覺得沒啥用,可以當作哈啤
下面是拖拉上傳代碼,后端PHP獲取到$_FILES之后就可以搞起來了
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>拖放上傳</title>
<style>
#imgContainer{background:#ccc;width:500px;height:500px;}
</style>
</head>
<body>
<p id="imgContainer"></p>
<p id="msg"></p>
</body>
<script>
var imgContainer,msgp;
window.onload = function(e){
imgContainer = document.getElementById('imgContainer');
msgp = document.getElementById('msg');
imgContainer.ondragover = function(e){
e.preventDefault();
}
imgContainer.ondrop = function(e){
e.preventDefault();
var f = e.dataTransfer.files[0];
//這時已經獲取到文件了,具體想要用第幾個文件自己處理,發post請求后端處理就行了!
//下面是圖片獲取到之后顯示在imgContainer中的流程
// var fileReader = new FileReader();
// fileReader.onload=function(){
// imgContainer.innerHTML = "<img src=\""+fileReader.result+"\">"
// }
// fileReader.readAsDataURL(f);
// showObj(e); //顯示上傳信息
// showObj(e.dataTransfer.files);
}
}
function showObj(obj){
var s = '';
for(var k in obj){s += k+":"+obj[k]+"<br/>";}
msgp.innerHTML = s;
}
</script>
</html>以上是H5實現拖拉上傳文件的方法的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!
網站名稱:H5實現拖拉上傳文件的方法
分享網址:http://www.yijiale78.com/article6/pchiig.html
成都網站建設公司_創新互聯,為您提供網站設計、小程序開發、網站設計公司、網站建設、網站制作、面包屑導航
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯