摘要:注意點在鼠標操作拖放期間,有一些事件可能觸發多次,比如和。可拖拽元素,建議使用,設定可拖拽元素的鼠標游標,提升交互。在中使用拖拽中使用可以直接綁定到組件上。
什么是 Drag and Drop (拖放)?
簡單來說,HTML5 提供了 Drag and Drop API,允許用戶用鼠標選中一個可拖動元素,移動鼠標拖放到一個可放置到元素的過程。
我相信每個人都或多或少接觸過拖放,比如瀏覽器多標簽頁之間的可拖放排序、手機中的App可以隨便拖放排序等等,Drag and Drop 已經給我們提供了更便捷、更靈活的網絡應用體驗。
HTML5 Drag and DropDnD 規范定義了基于事件的拖放機制和附加標記,以標記網頁上幾乎所有 draggable 的元素類型,一個典型的 drag 操作是這樣開始的:用戶用鼠標選中一個可拖動的(draggable)元素,移動鼠標到一個可放置的(droppable)元素,然后釋放鼠標。 在操作期間,會觸發一些事件類型,有一些事件類型可能會被多次觸發(比如drag 和 dragover 事件類型)。
總結起來很簡單:
Drag Source(What to drag) => Drop Target(Where to drop)
拖拽事件所有的拖拽事件都對應一個 global event handler,Dnd API 一個有8個事件,可以分為綁定在 Drag Source 上3個、綁定在 Drag Target 上5個
Drag SourceEvent | Description |
---|---|
dragstart | 當用戶開始拖動一個元素或選中的文本時觸發。 |
drag | 當拖動元素或選中的文本時觸發。 |
dragend | 當拖拽操作結束時觸發 (比如松開鼠標按鍵或敲“Esc”鍵)。 |
Event | Description |
---|---|
dragenter | 當拖動元素或選中的文本到一個可釋放目標時觸發。 |
dragover | 當元素或選中的文本被拖到一個可釋放目標上時觸發(每100毫秒觸發一次)。 |
dragexit | 當元素變得不再是拖動操作的選中目標時觸發。 |
dragleave | 當拖動元素或選中的文本離開一個可釋放目標時觸發。 |
drop | 當元素或選中的文本在可釋放目標上被釋放時觸發。 |
在鼠標操作拖放期間,有一些事件可能觸發多次,(比如:drag 和 dragover)。使用時注意防抖或節流
在 dragover 事件中使用 event.preventDefault() 阻止默認事件行為時,才能正確觸發 drop 事件
在 Firefox 瀏覽器中觸發 drop 時要使用 event.preventDefault() 阻止默認事件行為,以防止打開一個新的標簽
數據接口HTML拖拽的數據接口有三個 DataTransfer、DataTransferItem 和 DataTransferItemList。
在進行拖放操作時,DataTransfer 對象用來保存,通過拖放動作,拖動到瀏覽器的數據。它可以保存一項或多項數據、一種或者多種數據類型。
DataTransfer 常用屬性屬性 | 類型 | 描述 |
---|---|---|
dropEffect | String | 獲取 / 設置實際的放置效果,它應該始終設置成 effectAllowed 的可能值之一,copy、move、link、none |
effectAllowed | String | 用來指定拖動時被允許的效果。 |
Files | FileList | 保存一個被存儲數據的類型列表作為第一項,順序與被添加數據的順序一致。如果沒有添加數據將返回一個空列表。 |
types | DOMStringList | 包含一個在數據傳輸上所有可用的本地文件列表。如果拖動操作不涉及拖動文件,此屬性是一個空列表。 |
void clearData([in String type])
String getData(in String type)
void setData(in String type, in String data)
void setDragImage(in nsIDOMElement image, in long x, in long y)
注意點通過定義 MIME (Multipurpose Internet Mail Exchange)來指定數據傳輸類型,例如:text/plain
功能檢測想象一下我們想開發一個使用HTML5 DnD API來實現的豐富可交互式的應用。結果因為瀏覽器不支持,是不是很糟糕。對我們是否需要使用降級方案還是有很重要的參考意義的。
下面有兩種常用的方法來幫助我們來檢測。
caniuse ModernizrModernizr 是一個出色的可用于檢測用戶瀏覽器是否支持 HTML5 和 CSS3 功能的庫。
</>復制代碼
if (Modernizr.draganddrop) {
// Browser supports HTML5 DnD.
} else {
// Fallback to a library solution.
}
實現拖拽
HTML Attribute
實現拖拽元素只需要在dom標簽上加入 draggable="true"
CSS User Interface</>復制代碼
user-select
可拖拽元素,建議使用 user-select,避免用戶在拖拽時選取到內部元素。
</>復制代碼
[draggable="true"] {
/*
To prevent user selecting inside the drag source
*/
user-select: none;
-moz-user-select: none;
-webkit-user-select: none;
-ms-user-select: none;
}
cursor
可拖拽元素,建議使用 cursor,設定可拖拽元素的鼠標游標,提升交互。
</>復制代碼
[draggable="true"] {
cursor: move;
}
在 Vue 中使用拖拽
Vue 中使用 dnd 可以直接綁定 event 到組件上。
下面栗子包含的內容:
使用Vue實現拖放
拖放事件以及事件觸發的時機
拖放事件的一些效果處理
拖拽系統文件到瀏覽器
https://codesandbox.io/embed/...
DnD 能做什么?提升網頁上操作交互體驗
提供列表排序功能
本機與瀏覽器交互
HTML5游戲
...更多
推薦一些不錯的DnD庫interact.js - JavaScript drag and drop, resizing and multi-touch gestures with inertia and snapping for modern browsers (and also IE9+)
Sortable - Sortable — is a JavaScript library for reorderable drag-and-drop lists on modern browsers and touch devices.
draggable - The JavaScript Drag & Drop library your grandparents warned you about.
Vue.Draggable - Vue component allowing drag-and-drop sorting in sync with View-Model. Based on Sortable.js
vue-grid-layout - A draggable and resizable grid layout, for Vue.js.
vue-draggable-resizable - Vue2 Component for draggable and resizable elements.
react-dnd - Drag and Drop for React
react-beautiful-dnd - Beautiful and accessible drag and drop for lists with React
react-grid-layout - A draggable and resizable grid layout with responsive breakpoints, for React.
參考Mozilla HTML_Drag_and_Drop_API
Native HTML5 Drag and Drop
caniuse
Working with HTML5 Drag-and-Drop
</>復制代碼
原文:使用 Drag and Drop 給Web應用提升交互體驗
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/53304.html
摘要:接下來我們就用原生和快速實現這樣的拖放效果的內容很簡單,就是五個空的容器和一個可以被拖拽的元素注意點容器的的為,用于接收被拖拽的元素,可被拖拽的元素為,同時設置屬性為,表示該元素可以被拖拽。 拖放是很常見的一種交互效果,很多時候我們都會借助于第三方的控件來實現,其實用原生js實現起來也非常的方便。接下來我們就用原生js和css快速實現這樣的拖放效果: showImg(https://s...
摘要:接下來我們就用原生和快速實現這樣的拖放效果的內容很簡單,就是五個空的容器和一個可以被拖拽的元素注意點容器的的為,用于接收被拖拽的元素,可被拖拽的元素為,同時設置屬性為,表示該元素可以被拖拽。 拖放是很常見的一種交互效果,很多時候我們都會借助于第三方的控件來實現,其實用原生js實現起來也非常的方便。接下來我們就用原生js和css快速實現這樣的拖放效果: showImg(https://s...
摘要:接下來我們就用原生和快速實現這樣的拖放效果的內容很簡單,就是五個空的容器和一個可以被拖拽的元素注意點容器的的為,用于接收被拖拽的元素,可被拖拽的元素為,同時設置屬性為,表示該元素可以被拖拽。 拖放是很常見的一種交互效果,很多時候我們都會借助于第三方的控件來實現,其實用原生js實現起來也非常的方便。接下來我們就用原生js和css快速實現這樣的拖放效果: showImg(https://s...
閱讀 3882·2023-04-26 00:36
閱讀 2682·2021-11-16 11:44
閱讀 1106·2021-11-15 17:58
閱讀 1680·2021-09-30 09:47
閱讀 1221·2019-08-30 13:05
閱讀 1554·2019-08-30 12:55
閱讀 2421·2019-08-30 11:02
閱讀 2750·2019-08-29 17:01