溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

H5拖放技術(shù)有哪些語(yǔ)法

發(fā)布時(shí)間:2022-03-11 16:14:38 來(lái)源:億速云 閱讀:135 作者:iii 欄目:web開(kāi)發(fā)

這篇“H5拖放技術(shù)有哪些語(yǔ)法”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“H5拖放技術(shù)有哪些語(yǔ)法”文章吧。

  提到拖拽,我們都很熟悉,那么拖放呢?一字之差,代表的意義是不一樣的,拖拽就是拉著走,拖放就是有拖,有放,我們都知道原生 JS 拖拽效果的缺點(diǎn):

  1. 代碼相對(duì)復(fù)雜與冗余

  2. 僅限于在瀏覽器內(nèi)的元素間拖放

  3、不能實(shí)現(xiàn)跨頁(yè)面的拖放

  所以H5就出現(xiàn)了拖放技術(shù),與 JS 原生相比 HTML5 拖放的優(yōu)勢(shì):

  H5拖放技術(shù),drag&drop,對(duì)于瀏覽器的支持性:

  Internet Explorer 9、Firefox、Opera 12、Chrome 以及 Safari 5 支持拖放。注:在 Safari 5.1.2 中不支持拖放。

  那么它有哪些api語(yǔ)法,我們來(lái)看一下:

  1、draggable 屬性

  通過(guò) draggable 告訴瀏覽器哪些元素需要實(shí)現(xiàn)拖拽功能。有三個(gè)可選值:

  true: 元素可以被拖拽

  false:元素不能被拖拽

  auto:瀏覽器自己判斷元素是否能被拖拽 ( 默認(rèn) )

  2、對(duì)象拖放事件

  dragstart:按下鼠標(biāo)鍵并開(kāi)始移動(dòng)時(shí)觸發(fā)

  drag:在元素拖拽過(guò)程中持續(xù)觸發(fā)----相似與mousemove

  dragend:元素拖拽停止時(shí)觸發(fā)

  3、投放區(qū)事件流程

  元素被拖動(dòng)到有效的放置目標(biāo)時(shí),下列事件會(huì)依次發(fā)生:

  1). dragenter:當(dāng)拖拽對(duì)象進(jìn)入投放區(qū)時(shí)觸發(fā)

  2). dragover :拖拽對(duì)象在投放區(qū)內(nèi)移動(dòng)時(shí)持續(xù)觸發(fā)

  3). dragleave:元素被拖出了投放區(qū)時(shí)觸發(fā)

  4). drop:拖拽對(duì)象投放在投放區(qū)時(shí)觸發(fā)

  雖然所有元素都支持放置目標(biāo)事件,但這些元素默認(rèn)是不允許放置的,需要重寫事件的默認(rèn)行為,例如:

  在ondragover中一定要執(zhí)行 preventDefault()否則ondrop事件不會(huì)被觸發(fā)

  4、dataTransfer 對(duì)象--常用方法

  setDragImage (圖標(biāo),圖標(biāo)距指針X軸偏移值,Y軸偏移值 )

  指定一個(gè)圖標(biāo),當(dāng)拖動(dòng)發(fā)生時(shí),顯示在光標(biāo)下方

  5、dataTransfer 對(duì)象--常用屬性:

  dropEffect 表示被拖動(dòng)的元素能夠執(zhí)行哪種放置行為

  可能的值:

  “none” : 不能把拖動(dòng)的元素放在這里

  “move”: 把拖動(dòng)的元素移動(dòng)到放置目標(biāo)

  “copy”: 把拖動(dòng)的元素復(fù)制到放置目標(biāo)

  “l(fā)ink”: 放置目標(biāo)會(huì)打開(kāi)拖動(dòng)的元素(有URL)

  effectAllowed 允許拖動(dòng)元素的哪種dropEffect

  允許值:

  “copyLink” : 允許值為 copy 和 link 的 dropEffect

  “copyMove”: 允許值為 copy 和 move 的 dropEffect

  “l(fā)inkMove” : 允許值為 link和 move 的 dropEffect

  “all” : 允許任意的 dropEffect

  注意:dropEffect屬性搭配effectAllowed屬性使用在dragstart事件處理程序中設(shè)置effectAllowed屬性在dragover事件處理程序中設(shè)置dropEffect屬性dropEffect 的每個(gè)可能值都會(huì)導(dǎo)致光標(biāo)顯示為不同的符號(hào)

  6、files文件

  dataTransfer.files:如果是拖放文件,則返回正在拖放的文件列表FileList

  FileReader:專門用于讀取文件,F(xiàn)ileReader 接口提供一些讀取文件的方法與一個(gè)包含讀取結(jié)果的事件模型

  FileReader.readAsDataURL方法:參數(shù)為要讀取的文件對(duì)象,將文件讀取為DataUrl

  FileReader.事件:當(dāng)讀取文件成功完成的時(shí)候觸發(fā)此事件,在事件觸發(fā)后,你可以通過(guò)this.result來(lái)獲取讀取的文件數(shù)據(jù),如果是圖片,將返回格式的圖片數(shù)據(jù)。

以上就是關(guān)于“H5拖放技術(shù)有哪些語(yǔ)法”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

h5
AI