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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...