H5 拖拽操作

Posted liujunhang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了H5 拖拽操作相关的知识,希望对你有一定的参考价值。

H5 拖拽操作

前言

在原生H5中,可以通过提供的api实现在网页内元素的拖拽操作。相对于传统的写法更加的简单。

而想要实现拖拽,主要需要进行两个方面的工作,第一是给元素设置draggable=‘true‘属性,img和a标签是默认允许拖拽的。第二是编写拖拽相关的事件处理函数。

拖拽主要的过程

在整个拖拽的过程中,可以把行为分成两个部分,一部分是关于拖拽元素的操作,另外一个部分是关于拖拽元素最终放置的容器上的操作。

当拖拽元素时,拖拽事件执行的流程如下:

dragstart -> drag -> dragend 

dragstart事件的触发时机是在按住鼠标开始拖动的时候,只会触发一次。

drag事件是在按住鼠标拖动的过程中触发,是属于持续触发的状态。

dragend事件是在释放鼠标之后触发,此时无论是已经将目标放在了有效的位置还是放在了无效的位置上,都会触发这个事件。

技术图片

技术图片

放置元素主要经历的过程

当我们放置元素时,需要经历的事件变化流程如下:

dragenter -> dragover -> drop

dragenter 事件,当拖拽元素被拖拽到了目标元素上,就会被触发

dragover 事件,当拖拽的元素被拖拽到了目标元素上并且在目标元素上移动时,就会持续性的触发。

drop 事件,拖拽的元素放在了目标元素身上的时候会被触发。

tip: 这当中在dragover事件之后还包含了dragleave事件,当元素离开了目标元素时触发。

整体的拖拽流程如下:

dragstart->drag->dragenter->dragover->dragleave->drop->dragend

例如:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style type="text/css">
        .box {
            width:100px;
            height: 100px;
            background-color: lightblue;
        }
        #content {
            width:300px;
            height: 300px;
            border:2px solid #222;
            position: absolute;
            right:0;
            top:0;
        }
    </style>
</head>
<body>
    <div class="box" draggable='true'></div>

    <div id="content"></div>
</body>
<script type="text/javascript">
    var box = document.getElementsByTagName('div')[0];
    var content = document.getElementById('content');
    box.ondragstart = function() {
        console.log(1111)
        event.dataTransfer.setData('Text',this.className);
    }
    box.ondrag = function() {
        console.log(2222)
    }
    box.ondragend = function() {
        console.log(3333)
    }

    content.ondragenter = function() {
        console.log('enter')
    }
    content.ondragover = function() {
        console.log('over')
        event.preventDefault();
    }

    content.ondrop = function() {
        console.log('drop')
        var data = event.dataTransfer.getData('Text');
        this.appendChild(document.getElementsByClassName(data)[0])
    }
</script>
</html>

实现的效果:

技术图片

技术图片

tip: 想要顺利的完成拖拽,需要在dragover事件里阻止默认行为,event.preventDefault();

火狐的兼容问题

在火狐浏览器里,如果仅仅给元素设置draggable=‘true‘这个属性,是无法完成拖拽的[谷歌没有问题]。

要解决这个问题必须为拖拽元素绑定dragstart事件处理函数,并且在该函数中调用event.dataTransfer.setData函数

// box 是拖拽的元素
box.ondragstart = function() {
    console.log(1111)
    event.dataTransfer.setData('Text',this.className);
}

同时,在火狐浏览器当中,当我们直接进行拖拽的时候,发现会产生打开新选项卡的现象,解决办法是在所有的容器代码里,都加上阻止默认行为的代码:

event.preventDefault();
event.stopPropagation();

以上是关于H5 拖拽操作的主要内容,如果未能解决你的问题,请参考以下文章

h5-拖拽接口

H5简单拖放(Drag/Drop)

H5中的拖拽文件上传

h5学习--七个h5拖拽事件

H5拖拽 构造拖拽及缩放 pdf展示

h5拖拽上传图片