pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

HTML5拖放API實現(xiàn)拖放排序的實例代碼

HTML5 中提供了直接拖放的 API,極大的方便我們實現(xiàn)拖放效果,不需要去寫一大堆的 js,只需要通過監(jiān)聽元素的拖放事件就能實現(xiàn)各種拖放功能。

前言

HTML5 中提供了直接拖放的 API,極大的方便我們實現(xiàn)拖放效果,不需要去寫一大堆的 js,只需要通過監(jiān)聽元素的拖放事件就能實現(xiàn)各種拖放功能。

想要拖放某個元素,必須設(shè)置該元素的 draggable 屬性為 true,當該屬性為 false 時,將不允許拖放。而 img 元素和 a 元素都默認設(shè)置了 draggable 屬性為 true,可直接拖放,如果不想拖放這兩個元素,把屬性設(shè)為 false 即可。

拖放事件

拖放事件由不同的元素產(chǎn)生。一個元素被拖放,他可能會經(jīng)過很多個元素上,最終到達想要放置的元素內(nèi)。這里,我暫時把被拖放的元素稱為源對象,被經(jīng)過的元素稱為過程對象,到達的元素我稱為目標對象。不同的對象產(chǎn)生不同的拖放事件。

源對象:

  1. dragstart:源對象開始拖放。
  2. drag:源對象拖放過程中。
  3. dragend:源對象拖放結(jié)束。

過程對象:

  1. dragenter:源對象開始進入過程對象范圍內(nèi)。
  2. dragover:源對象在過程對象范圍內(nèi)移動。
  3. dragleave:源對象離開過程對象的范圍。

目標對象:

  1. drop:源對象被拖放到目標對象內(nèi)。
<div id="source" draggable="true">a元素</div>
<div id="process">b元素</div>
<div id="target">c元素</div>

<script>
    var source = document.getElementById('source'),     // a元素
        process = document.getElementById('process'),   // b元素
        target = document.getElementById('target');     // c元素
    
    source.addEventListener('dragstart',function(ev){   // dragstart事件由a元素產(chǎn)生
        console.log('a元素開始被拖動');
    },false)

    process.addEventListener('dragenter',function(ev){  // dragenter事件由b元素產(chǎn)生
        console.log('a元素開始進入b元素');
    },false)
    process.addEventListener('dragleave',function(ev){  // dragleave事件由b元素產(chǎn)生
        console.log('a元素離開b元素');
    },false)

    target.addEventListener('drop',function(ev){        // drop事件由c元素產(chǎn)生
        console.log('a元素拖放到c元素了');
        ev.preventDefault();
    },false)
    document.ondragover = function(e){e.preventDefault();}
</script>

dataTransfer 對象

在所有拖放事件中提供了一個數(shù)據(jù)傳遞對象 dataTransfer,用于在源對象和目標對象間傳遞數(shù)據(jù)。接下來認識一下這個對象的方法和屬性,來了解它是如何傳遞數(shù)據(jù)的。

setData()

該方法向 dataTransfer 對象中存入數(shù)據(jù)。接收兩個參數(shù),第一個表示要存入數(shù)據(jù)種類的字符串,現(xiàn)在支持有以下幾種:

  1. text/plain:文本文字。
  2. text/html:HTML文字。
  3. text/xml:XML文字。
  4. text/uri-list:URL列表,每個URL為一行。

第二個參數(shù)為要存入的數(shù)據(jù)。例如:

event.dataTransfer.setData('text/plain','Hello World');

getData()

該方法從 dataTransfer 對象中讀取數(shù)據(jù)。參數(shù)為在 setData 中指定的數(shù)據(jù)種類。例如:

event.dataTransfer.getData('text/plain');

clearData()

該方法清除 dataTransfer 對象中存放的數(shù)據(jù)。參數(shù)可選,為數(shù)據(jù)種類。若參數(shù)為空,則清空所有種類的數(shù)據(jù)。例如:

event.dataTransfer.clearData();

setDragImage()

該方法通過用img元素來設(shè)置拖放圖標。接收三個參數(shù),第一個為圖標元素,第二個為圖標元素離鼠標指針的X軸位移量,第三個為圖標元素離鼠標指針的Y軸位移量。例如:

var source = document.getElementById('source'),
    icon = document.createElement('img');

icon.src = 'img.png';

source.addEventListener('dragstart',function(ev){
    ev.dataTransfer.setDragImage(icon,-10,-10)
},false)

effectAllowed 和 dropEffect 屬性

這兩個屬性結(jié)合起來設(shè)置拖放的視覺效果。

值得注意的是:IE 不支持 dataTransfer 對象。對,不管哪個 IE 版本都不支持。

實現(xiàn)拖放排序

上面已經(jīng)熟悉了拖放 API 的使用,我們來實現(xiàn)個簡單的拖放排序,這也是在項目中比較常見的。先來理一下思路:

  1. 在一個列表中,每個元素都可以被拖放,那首先要給每個元素設(shè)置 draggable 屬性為 true。
  2. 監(jiān)聽每個元素的 dragstart 事件,對源對象做樣式處理來區(qū)分。
  3. 監(jiān)聽每個元素的 dragenter 事件,當源對象進入到當前元素里,就把源對象添加到該元素之前。這樣子后面的元素就會被源對象擠下去了,實現(xiàn)了排序的效果。
  4. 但是會發(fā)現(xiàn),源對象無法排到最后一個去,只能在倒數(shù)第二。這時就要監(jiān)聽 dragleave 事件,當過程對象是最后一個元素時,源對象離開了過程對象,這時就把源對象添加到最后去。
【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學習交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了有關(guān)HTML5頁面在iPhoneX適配問題,需要的朋友可以參考下
本篇文章主要介紹了html5中canvas圖表實現(xiàn)柱狀圖的示例,本文使用canvas來實現(xiàn)一個圖表,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
Adobe公司出品的多媒體處理軟件產(chǎn)品線較多,涵蓋了音視頻編輯、圖像處理、平面設(shè)計、影視后期等領(lǐng)域。這篇文章主要介紹了Adobe Html5 Extension開發(fā)初體驗圖文教程,非常不錯,需要的朋
這篇文章主要介紹了基于HTML5的WebGL經(jīng)典3D虛擬機房漫游動畫,需要的朋友可以參考下
這篇文章主要介紹了html5實現(xiàn)移動端適配完美寫法,需要的朋友可以參考下
本篇文章主要介紹了HTML5響應(yīng)式(自適應(yīng))網(wǎng)頁設(shè)計的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
主站蜘蛛池模板: 玻璃钢罐_玻璃钢储罐_盐酸罐厂家-河北华盛节能设备有限公司 | 芝麻黑-芝麻黑石材厂家-永峰石业 | 珠海网站建设_响应网站建设_珠海建站公司_珠海网站设计与制作_珠海网讯互联 | 冷藏车厂家|冷藏车价格|小型冷藏车|散装饲料车厂家|程力专用汽车股份有限公司销售十二分公司 | 桂林腻子粉_内墙外墙抗裂砂浆腻子粉推荐广西鑫达涂料厂家供应 | 世纪豪门官网 世纪豪门集成吊顶加盟电话 世纪豪门售后电话 | 气力输送_输送机械_自动化配料系统_负压吸送_制造主力军江苏高达智能装备有限公司! | 螺钉式热电偶_便携式温度传感器_压簧式热电偶|无锡联泰仪表有限公司|首页 | 啤酒设备-小型啤酒设备-啤酒厂设备-济南中酿机械设备有限公司 | 移动机器人产业联盟官网| 层流手术室净化装修-检验科ICU改造施工-华锐净化工程-特殊科室建设厂家 | 编织人生 - 权威手工编织网站,编织爱好者学习毛衣编织的门户网站,织毛衣就上编织人生网-编织人生 | 上海网站建设-上海网站制作-上海网站设计-上海做网站公司-咏熠软件 | 大学食堂装修设计_公司餐厅效果图_工厂食堂改造_迈普装饰 | 郑州电线电缆厂家-防火|低压|低烟无卤电缆-河南明星电缆 | 净化车间_洁净厂房_净化公司_净化厂房_无尘室工程_洁净工程装修|改造|施工-深圳净化公司 | 蔬菜配送公司|蔬菜配送中心|食材配送|饭堂配送|食堂配送-首宏公司 | 双齿辊破碎机-大型狼牙破碎机视频-对辊破碎机价格/型号图片-金联机械设备生产厂家 | 钢制暖气片散热器_天津钢制暖气片_卡麦罗散热器厂家 | 济南品牌包装设计公司_济南VI标志设计公司_山东锐尚文化传播 | 样品瓶(色谱样品瓶)百科-浙江哈迈科技有限公司 | 酒糟烘干机-豆渣烘干机-薯渣烘干机-糟渣烘干设备厂家-焦作市真节能环保设备科技有限公司 | 耐火浇注料-喷涂料-浇注料生产厂家_郑州市元领耐火材料有限公司 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | 美缝剂_美缝剂厂家_美缝剂加盟-地老板高端瓷砖美缝剂 | 盛源真空泵|空压机-浙江盛源空压机制造有限公司-【盛源官网】 | 干洗店加盟_洗衣店加盟_干洗店设备-伊蔻干洗「武汉总部」 | 二手Sciex液质联用仪-岛津气质联用仪-二手安捷伦气质联用仪-上海隐智科学仪器有限公司 | 臭氧灭菌箱-油桶加热箱-原料桶加热融化烘箱-南京腾阳干燥设备厂 臭氧发生器_臭氧消毒机 - 【同林品牌 实力厂家】 | 振动台-振动试验台-振动冲击台-广东剑乔试验设备有限公司 | 浙江美尔凯特智能厨卫股份有限公司| 锤式粉碎机,医药粉碎机,锥式粉碎机-无锡市迪麦森机械制造有限公司 | 网络推广公司_网络营销方案策划_企业网络推广外包平台-上海澜推网络 | 金属雕花板_厂家直销_价格低-山东慧诚建筑材料有限公司 | 高柔性拖链电缆_卷筒电缆_耐磨耐折聚氨酯电缆-玖泰特种电缆 | 退火炉,燃气退火炉,燃气热处理炉生产厂家-丹阳市丰泰工业炉有限公司 | 合肥展厅设计-安徽展台设计-合肥展览公司-安徽奥美展览工程有限公司 | 上海网站建设-上海网站制作-上海网站设计-上海做网站公司-咏熠软件 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 耐磨焊丝,堆焊焊丝,耐磨药芯焊丝,碳化钨焊丝-北京耐默公司 | 新车测评网_网罗汽车评测资讯_汽车评测门户报道 | 冷轧机|两肋冷轧机|扁钢冷轧机|倒立式拉丝机|钢筋拔丝机|收线机-巩义市华瑞重工机械制造有限公司 |