HTML5拖拽實現示例

来源:http://www.cnblogs.com/oovwall/archive/2016/02/24/5213580.html
-Advertisement-
Play Games

HTML5現在前端圈中,已然成為一個不那麼新的技術辭彙了,很多公司也把HTML5也當成了硬性的技能要求,但是很多前端恐怕都不瞭解HTML5的拖拽怎麼實現吧。 看了下極客學院的視頻,大概的瞭解了下思路。所以整理備份,便於以後查閱。先上示例: index.html 1 <!doctype html> 2


HTML5現在前端圈中,已然成為一個不那麼新的技術辭彙了,很多公司也把HTML5也當成了硬性的技能要求,但是很多前端恐怕都不瞭解HTML5的拖拽怎麼實現吧。

看了下極客學院的視頻,大概的瞭解了下思路。所以整理備份,便於以後查閱。先上示例:

index.html

 1 <!doctype html>
 2 <html>
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Drag</title>
 6     <style>
 7         .box{
 8             width: 400px;
 9             height: 400px;
10             float: left;
11         }
12         #box1{
13             background: #CCC;
14         }
15         #box2{
16             background: #FF0;
17         }
18     </style>
19 </head>
20 <body>
21 <div id="box1" class="box"></div>
22 <div id="box2" class="box"></div>
23 <img src="http://pica.zol-img.com.cn/2016/02/1ace90ad77db716547614a18c4a9263g.jpg" alt="" id="img1" />
24 
25 <script src="app1.js"></script>
26 </body>
27 </html>

 

 

app1.js

 1 /**
 2  *   app1.js
 3  */
 4 
 5 var oBox1,
 6     oBox2,
 7     oImg1;
 8 
 9 window.onload = function(){
10     oBox1 = document.getElementById('box1');
11     oBox2 = document.getElementById('box2');
12     oImg1 = document.getElementById('img1');
13 
14     //
15     oBox1.ondragover = oBox2.ondragover = function(e){
16         e.preventDefault();
17     };
18 
19     //
20     oImg1.ondragstart = function(e){
21         e.dataTransfer.setData('text', e.target.id);
22     };
23 
24     oBox1.ondrop = dropImg;
25     oBox2.ondrop = dropImg;
26 };
27 
28 function dropImg(e){
29     e.preventDefault();
30     var tempImg = document.getElementById(e.dataTransfer.getData('text'));
31     e.target.appendChild(tempImg);
32 }

 

涉及知識點

在拖放的過程中會觸發以下事件:
在拖動目標上觸發事件 (源元素)
  ondragstart - 用戶開始拖動元素時觸發
  ondrag - 元素正在拖動時觸發
  ondragend - 用戶完成元素拖動後觸發

釋放目標時觸發的事件
  ondragenter - 當被滑鼠拖動的對象進入其容器範圍內時觸發此事件
  ondragover - 當某被拖動的對象在另一對象容器範圍內拖動時觸發此事件
  ondragleave - 當被滑鼠拖動的對象離開其容器範圍內時觸發此事件
  ondrop - 在一個拖動過程中,釋放滑鼠鍵時觸發此事件

 

event對象(以e代替)

e.target

  W3Cschool上的解釋是:返回觸發此事件的元素(事件的目標節點),這個target屬性只相容ie9及以上

e.preventDefault()

  取消事件的預設動作。

e.dataTransfer.setData()

  設置被拖數據的數據類型和值。

e.dataTransfer.setData("Text",ev.target.id);       //第一個參數為Text(小寫的也行)

e.dataTransfer.getData()

  獲得被拖的數據。

e.dataTransfer.getData("Text");

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近一直在惡補基礎JS H5 CSS3的基礎知識 關於這個瀑布流: 本來打算看著教程來做的。 不過 感覺理解起來有點複雜。 SO, 自己參考教程默寫了一個。。 目前我所接觸過的瀑布流佈局分為2大類 主要區分在於 float佈局 或者position佈局 點擊這裡下載Demo 貼下源碼:(可能有些BU
  • 基礎數據結構與演算法 現在有兩個不同的JSON,比較複雜,可以參考這裡的DEMO中返回的JSON。要比較它們的差異,除了用現成的工具如beyond compare以外,如果我們的機器上沒有安裝這個工具,能如何較快解決?作為一個程式員,一個個對比是不可行的,對比完也不會有什麼收穫。我會把之放進Excel
  • 21世紀,瀏覽器雜七雜八,足以讓你眼花繚亂。我們在做頁面相容性測試的時候,面對眾多的瀏覽器該如何調試我們的web頁面?其實,如果你瞭解了瀏覽器的內核,那麼就不會覺得頭疼。因為它們的內核並不是和他的數量一樣那麼多,常見的幾類內核可以歸為:Trident、Gecko、WebKit、Presto 四種。
  • 效果展示: html: <div class="sidebar"> <ul> <li>優先順序 <ul> <li><aonclick=""class="sidebar-selected">全部</a></li> <li><aonclick="">P1</a></li> <li><aonclick=""
  • underscore.js解析
  • 其實函數引用的外部變數都是最後一次的值。 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> #box{ width:100px; height:100px; b
  • AngularJS通過新的屬性與表達式來擴展HTML,有一種很形象的叫法,定義它為聲明式語言。 為剋服HTML在構建應用上的不足而設計! 這是它的目標。 它的官網進不去,應該是被牆了,這是goegle的團隊弄的。所以找了個應用AngularJS的網站,然後另存為下來的。 以一段簡單的代碼開頭 <di
  • 參考: http://www.cnblogs.com/TomXu/archive/2011/11/21/2257154.html http://knockoutjs.com/documentation/introduction.html 複習:AngularJS的數據綁定 顯示文本 <p>{{gre
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...