首頁 > web前端 > js教程 > 主體

html drag拖曳事件

韦小宝
發布: 2018-05-18 15:39:46
原創
3415 人瀏覽過

在html中,事件的處理都是在js中完成的,html,js和css是密不可分的。以下就是在js中處理拖曳事件的例子。

拖曳事件分兩大塊,一塊是對拖曳的目標上的處理(即拖曳目標);一塊是對拖曳到的目標上的處理(即釋放目標)。

在拖曳目標上觸發事件 (來源元素):

    ondragstart - 使用者開始拖曳元素時觸發

    ondrag - 元素正在拖曳時觸發

    ondragend - 使用者完成元素拖曳後觸發

    ondragend - 使用者完成元素拖曳後觸發

# 時觸發目標時觸發的事件:

##    ondragenter - 當被滑鼠拖曳的物件進入其容器範圍內時觸發此事件

    ondragover - 當某被拖曳的物件在另一物件容器範圍內拖曳時觸發此事件

    ondragleave - 當被滑鼠拖曳的物件離開其容器範圍內時觸發此事件    ondrop - 在一個拖曳過程中,釋放滑鼠鍵時觸發此事件

實作程式碼如下:box1和lists可以互相拖曳

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        #box1{width: 200px;height: 250px;border:2px solid red;}
        #lists{ width:200px; height:250px; list-style: none;padding: 0;margin: 10px 0px; border:2px solid blue;}
        li{width: 150px;height: 30px; margin: 5px 0; padding:0;background: #ccc; line-height:30px;text-align: center ;}
    </style>
    <script>
        window.onload=function () {
            var box1=document.getElementById("box1");
            var lists=document.getElementById("lists");
            var lis=document.getElementsByTagName("li");
            for(var i=0;i<lis.length;i++){
                lis[i].draggable=true;
                lis[i].flag=false;
                //1、拖拽开始
                lis[i].ondragstart=function () {
                    this.flag=true;
                }
                //2、拖拽移动
                 two.ondrag=function () {

                }
                //3、拖拽结束
                lis[i].ondragend=function () {
                    this.flag=false;
                }
            }
            //投放区事件
            //1、进入投放区
            box1.ondragenter=function (e) {
                e.preventDefault();
            }
            //2、在投放区内移动
            box1.ondragover=function (e) {
                e.preventDefault();
            }
            //3、离开投放区
            box1.ondragleave=function (e) {
                e.preventDefault();
            }
            //4、完成投放 此时可以在投放区内做处理
            box1.ondrop=function (e) {
                e.preventDefault();
                for(var i=0;i<lis.length;i++){
                    if(lis[i].flag){
                        box1.appendChild(lis[i]);
                    }
                }
            }

            lists.ondragenter=function (e) {
                e.preventDefault();
            }
            lists.ondragover=function (e) {
                e.preventDefault();
            }
            lists.ondragleave=function (e) {
                e.preventDefault();
            }
            lists.ondrop=function (e) {
                e.preventDefault();
                for(var i=0;i<lis.length;i++){
                    if(lis[i].flag){
                        lists.appendChild(lis[i]);
                    }
                }
            }
        }
    </script>
</head>
<body>
    <p id="box1"></p>
    <ul id="lists">
        <li>数据1</li>
        <li>数据2</li>
        <li>数据3</li>
        <li>数据4</li>
        <li>数据5</li>
        <li>数据6</li>
    </ul>
</body>
</html>
登入後複製

##其中: getElementsByTagName() 方法可傳回帶有指定標籤名的物件的集合。

e.preventDefault();是阻止系統預設的拖曳事件。

appendChild()是新增控制項到指定控制項。

e.preventDefault();
登入後複製
以上就是html drag拖曳事件的所有內容了,希望帶給大家幫助。

相關推薦:

#用JS和html做一個簡易畫板程式碼

Js操作DOM物件的流程############html js 有關問題#######

以上是html drag拖曳事件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板