當(dāng)前位置:首頁 >  站長 >  編程技術(shù) >  正文

HTML5拖拽文件上傳的示例代碼

 2021-03-19 17:45  來源: 腳本之家   我來投稿 撤稿糾錯

  域名預(yù)訂/競價,好“米”不錯過

這篇文章主要介紹了HTML5拖拽文件上傳的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

上傳文件

HTML5新增了文件API,提供客戶端本地操作文件的可能.

我們可以通過file表單或拖放操作選擇文件,還可以通過JavaScript讀取文件的名稱、大小、類型、和修改時間.

file類型的input表單新增了files屬性,保存我們上傳文件的信息,如果要實現(xiàn)多文件上傳,可以設(shè)置input的multiple屬性.

可以使用accept屬性規(guī)定文件上傳的MIME類型 例如’image/jpeg’

<form action="#">
<div class="form-group">
<label for="input_1">請選擇文件</label>
<input id="input_1" class="form-control" name="input_1" type="file">
</div>
<div class="form-group">
<button id="btn_1" class="btn btn-default" type="button">讀取文件信息</button>
</div>
</form>
<pre id="result"></pre>
</div>
<script>
var btn = document.querySelector('#btn_1');
var input = document.querySelector('#input_1');
btn.addEventListener('click', function() {
// 獲取文件域中選擇的文件
// var file = input.files[0];
var file = input.files.item(0);
if (file) {
result.innerHTML =
'文件名:' + file.name + '\n文件最近修改時間:' + file.lastModifiedDate+ '\n文件類型:' + file.type + '\n文件大?。? + file.size + '字節(jié)'
} else {
result.innerHTML = '沒有選擇任何文件';
}
});
</script>

頁面拖拽操作

對于被拖拽的元素,HTML5增加了三個事件用于監(jiān)聽拖拽的過程

dragstart 拖拽開始

drag 正在拖拽

dragend 拖拽結(jié)束

<body>
<div id="one" style="width: 300px;height: 300px;border: 1px solid red"></div>
<div id="two" style="width: 100px;height: 100px;border: 1px solid blue" draggable="true"></div>
</body>
<script type="text/javascript">
two.ondragstart = function(e){
// e.preventDefault();
console.log(e);
e.dataTransfer.setData("Text",e.target.id);
console.log(e.dataTransfer.getData("Text",e.target.id));
one.innerHTML = '開始'
}
two.ondrag = function(e){
one.innerHTML += '拖動中'
}
two.ondragend = function(e){
one.innerHTML = '結(jié)束'
}
</script>

想要拖拽元素,必須設(shè)置draggable屬性

頁面默認的動作是拖拽后回到原位

在拖動階段,我們可以存儲被拖動元素的屬性或者狀態(tài)到事件對象的dataTransfer中,如果出現(xiàn)跳轉(zhuǎn),則是瀏覽器默認的事件被觸發(fā),我們需要使用e.preventDefault()來阻止默認事件。

投放區(qū)的事件

對于被拖的元素而言,拖向何處則為投放區(qū),投放區(qū)的事件如下:

dragenter 被拖放元素進入

dragover 被拖放元素移動

dragleave 被拖放元素離開

<body>
<div id="one" style="width: 300px;height: 300px;border: 1px solid red"></div>
<div id="two" style="width: 100px;height: 100px;border: 1px solid blue" draggable="true"></div>
</body>
<script type="text/javascript">
one.ondragenter = function(e){
// e.preventDefault();
console.log(e);
one.innerHTML = '開始'
}
one.ondragover = function(e){
one.innerHTML += '拖動中'
}
one.ondragleave = function(e){
one.innerHTML = '結(jié)束'
}
</script>

而drop則是監(jiān)聽被拖拽物拖拽到投放區(qū)并松開鼠標(biāo)的事件,他可以接收到dataTransfer中的數(shù)據(jù),所以我們的頁面內(nèi)拖拽可以寫成如下效果:

<style type="text/css">
*{
box-sizing: border-box;
}
</style>
<body>
<div id="one" style="width: 300px;height: 300px;border: 1px solid red"></div>
<div id="two" style="width: 100px;height: 100px;border: 1px solid blue;display: flex;">
<div style="width: 50px;height: 100px;border:1px solid black;">第一個</div>
<div style="width: 50px;height: 100px;border:1px solid pink;">第二個</div>
</div>
</body>
<script type="text/javascript">
one.ondragover = function(e) {
e.preventDefault();
}
two.onmousedown = function(e){
e.target.draggable = true;
e.target.ondragstart = function(ev) {
ev.dataTransfer.setData("Text", ev.target.innerHTML);
}
e.target.ondragend = function(){
two.removeChild(this)
}
}
one.ondrop = function(e) {
var div = document.createElement('div')
div.style = "width: 50px;height: 100px;border:1px solid black;"
div.innerHTML = e.dataTransfer.getData("Text")
this.appendChild(div)
}
</script>

對于谷歌瀏覽器,e.dataTransfer.setData(key,value)會導(dǎo)致拖拽到投放區(qū)域外的時候瀏覽器默認搜索設(shè)置的值。如果需要,我們可以屏蔽它

對于火狐瀏覽器,沒有e.dataTransfer.setData(key,value)還不行。我們可以直接設(shè)置鍵值對為null,"";

最新版本的谷歌和火狐瀏覽器沒有發(fā)現(xiàn)問題

drop事件并不能直接觸發(fā),因為默認的松開鼠標(biāo)我們的拖拽物會返回原來的位置,并不會掉落,所以我們應(yīng)該阻止投放區(qū)域的默認事件.

拖拽文件上傳

經(jīng)過觀察,事件對象中的dataTransfer也存在files屬性,我們可以用熟悉的方法上傳拖拽進來的文件:

<body>
<div id="one" style="width: 300px;height: 300px;border: 1px solid red"></div>
</body>
<script type="text/javascript">
one.ondragover = function(e) {
e.preventDefault();
}
one.ondrop = function(e) {
e.preventDefault()
console.log(e.dataTransfer.files[0]);
}
</script>

然后做Ajax文件上傳即可

one.ondrop = function(e) {
e.preventDefault()
var file = e.dataTransfer.files[0];
var formData = new FormData();
formData.append("aa", file);
var xml = new XMLHttpRequest();
xml.open("post", url, false);
xml.send(formData);
}

到此這篇關(guān)于HTML5拖拽文件上傳的示例代碼的文章就介紹到這了,更多相關(guān)HTML5拖拽上傳內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

來源:腳本之家

鏈接:https://www.jb51.net/html5/766229.html

申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機遇!

相關(guān)標(biāo)簽
html5

相關(guān)文章

  • Html5移動端div固定到底部實現(xiàn)底部導(dǎo)航條的幾種方式

    這篇文章主要介紹了Html5移動端div固定到底部實現(xiàn)底部導(dǎo)航條的幾種方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

    標(biāo)簽:
    html5
  • HTML5 層的疊加的實現(xiàn)

    這篇文章主要介紹了HTML5層的疊加的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

    標(biāo)簽:
    html5
  • HTML5 背景的顯示區(qū)域?qū)崿F(xiàn)

    這篇文章主要介紹了HTML5背景的顯示區(qū)域?qū)崿F(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

    標(biāo)簽:
    html5
  • html5關(guān)于外鏈嵌入頁面通信問題

    這篇文章主要介紹了html5關(guān)于外鏈嵌入頁面通信問題(postMessage解決跨域通信),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

    標(biāo)簽:
    html5
  • HTML5 video進入全屏和退出全屏的實現(xiàn)方法

    這篇文章主要介紹了HTML5video進入全屏和退出全屏的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

    標(biāo)簽:
    html5

熱門排行

信息推薦