美文网首页
H5 拖放事件详解

H5 拖放事件详解

作者: 用技术改变世界 | 来源:发表于2019-05-17 12:05 被阅读0次

拖放事件

H5的拖放事件提供了多个接口:

1、drag:当元素或者选中的文本被拖动时触发(每几百毫秒触发一次),应用在被拖拽元素上

2、dragend:当拖动操作结束时触发(通过释放鼠标按钮或者点击转义键),应用在被拖拽元素上

3、dragenter:当一个被拖动的元素或者选中的文本进入一个有效的放置目标时触发,应用在目标元素上

4、dragexit:当元素不再是拖动操作的直接选择元素时触发(很少使用)

5、dragleave:当拖动元素或者选中的文本离开有效的放置区域时触发,应用在目标元素上

6、dragover:当元素或者选中的文本被拖动到有效放置区域上方时触发(每几百毫秒触发一次),应用在目标元素上

7、dragstart:当用户开始拖动元素或者拖动选中文本时触发,应用在被拖拽元素上

8、drop:当元素或选中的文本在有效区域放置时触发,应用在目标元素上

1

2

3

4

5

6

7

8

9

<div class="dropzone">

  <div id="draggable" draggable="true" ondragstart="event.dataTransfer.setData('text/plain',null)">

  <!--为兼容IE dataTransfer只能放在这里-->

    This div is draggable

  </div>

</div>

<div class="dropzone"></div>

<div class="dropzone"></div>

<div class="dropzone"></div>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

var dragged;

/* 事件在拖拽元素上触发 */

document.addEventListener("drag", function( event ) {

}, false);

/* 事件在拖拽元素上触发 */

document.addEventListener("dragstart", function( event ) {

  // 存储相关的拖拽元素

  dragged = event.target;

  // 设置拖拽元素的透明度

  event.target.style.opacity = .5;

}, false);

/* 事件在拖拽元素上触发 */

document.addEventListener("dragend", function( event ) {

  // 重设透明度

  event.target.style.opacity = "";

}, false);

/* 事件在目标区域触发 */

document.addEventListener("dragover", function( event ) {

  // 默认情况下是无法允许一个元素放置在另一个元素上的,要放置必须阻止默认行为

  event.preventDefault();

}, false);

/* 事件在目标区域触发 */

document.addEventListener("dragenter", function( event ) {

  // 当拖拽元素进入潜在放置区域时,高亮处理

  if ( event.target.className == "dropzone" ) {

      event.target.style.background = "purple";

  }

}, false);

/* 事件在目标区域触发 */

document.addEventListener("dragleave", function( event ) {

  // 当拖拽元素离开潜在放置区域时重置该目标区域的背景

  if ( event.target.className == "dropzone" ) {

      event.target.style.background = "";

  }

}, false);

document.addEventListener("drop", function( event ) {

  // 阻止默认行为(drop的默认处理方式是当初链接处理)

  event.preventDefault();

  // 把拖拽元素移入目标区域

  //这里要经过两步处理

  // 1、先把拖拽元素从原父元素中删除(这步不是必须的)

  ///2、然后再添加到目标区域

  if ( event.target.className == "dropzone" ) {

      event.target.style.background = "";

      dragged.parentNode.removeChild( dragged );

      event.target.appendChild( dragged );

  }

}, false);

event.dataTransfer

在进行拖放操作时,DataTransfer 对象用来保存被拖动的数据。它可以保存一项或多项数据、一种或者多种数据类型

这个对象在所有的拖动事件属性dataTransfer 都是可用的,但是不能单独创建。

dataTransfer属性(比较多,简单罗列几个)

dropEffect:

设置实际的放置效果,它应该始终设置成 effectAllowed 的可能值之一

可能的值:

copy:复制到新的位置move:移动到新的位置.link:建立一个源位置到新位置的链接.none:禁止放置(禁止任何操作).

设置其他值会导致拖放失败

effectAllowed:

用来指定拖动时被允许的效果

可能的值:

copy:复制到新的位置.move:移动到新的位置 .link:建立一个源位置到新位置的链接.copyLink: 允许复制或者链接.copyMove: 允许复制或者移动.linkMove: 允许链接或者移动.all: 允许所有的操作.none: 禁止所有操作.uninitialized: 缺省值(默认值), 相当于 all.

设置其他值会导致拖放失败

items:

拖拽的数据集合

types:

该属性返回一个DOMStringList对象,该对象包括了存入dataTransfer中数据的所有类型,返回值是一个数组

dataTransfer方法(比较多,简单罗列几个)

setData()

将指定格式的数据赋值给dataTransfer对象,参数format定义数据的格式也就是数据的类型,data为待赋值的数据,有点像jquery里面的data

如果指定的数据类型不存在,它将添加到的末尾,这样类型列表中的最后一个项目将是新的格式。如果已经存在的数据类型,替换相同的位置的现有数据。就是,当更换相同类型的数据时,不会更改类型列表的顺序。

getData(format)

从dataTransfer对象中获取指定格式的数据,format代表数据格式,如果给定类型的数据不存在或者数据转存(data transfer)没有包涵数据,方法将返回一个空字符串。

这个数据将仅仅在放置动作发生时在drop时间中是可用的

clearData([format])

从dataTransfer对象中删除指定格式的数据,参数可选,若不给出,则为删除对象中所有的数据。

addElement(element)

设置拖动源。通常不需要改变这项,如果修改将会影响拖动的那个节点和dragend事件的触发。默认目标是被拖动的节点。

setDragImage(image,x,y)

设置拖放操作的自定义图标。其中element设置自定义图标,x设置图标与鼠标在水平方向上的距离,y设置图标与鼠标在垂直方向上的距离。

大多数情况下,这项不用设置,因为被拖动的节点被创建成默认图片。

参数

image

要用作拖动反馈图像元素

x

图像内的水平偏移量.

y

图像内的垂直偏移量.

案例

1

2

3

4

5

6

div>div{

    display:inline-block;

    padding: 10px;

    background-color: #aaa;

    margin: 3px;

}

1

2

3

4

5

6

7

8

9

10

11

<div style="width:600px;border:1px solid black;">

    <h2>可将喜欢的项目拖到收藏夹</h2>

    <div draggable="true" ondragstart="dsHandler(event);">勿忘心安</div>

    <div draggable="true" ondragstart="dsHandler(event);">照顾自己</div>

    <div draggable="true" ondragstart="dsHandler(event);">Number 9</div>

    <div draggable="true" ondragstart="dsHandler(event);">崇拜</div>

</div>

<div id="dest" style="width:400px;height:400px;border:1px solid black;float:left;">

    <h2 ondragleave="return false;">收藏夹</h2>

</div>

<div id="gb" draggable="false" style="width:100px;height:100px;border:1px solid red;float:left;">我是垃圾桶</div>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

var dest = document.getElementById("dest");

var dsHandler = function (evt){

    evt.dataTransfer.setData("text/plain","<item>"+evt.target.innerHTML);

}

dest.ondrop = function(evt){

    var text = evt.dataTransfer.getData("text/plain");

    if(text.indexOf("<item>") == 0){

        var newEle = document.createElement("div");

        newEle.id = new Date().getUTCMilliseconds();

        newEle.innerHTML = text.substring(6);

        newEle.draggable = "true";

        newEle.ondragstart = function(evt){

            evt.dataTransfer.setData("text/plain","<remove>"+newEle.id);

        }

        dest.appendChild(newEle);

    }

}

document.getElementById("gb").ondrop = function(evt){

    var id = evt.dataTransfer.getData("text/plain");

    if(id.indexOf("<remove>") == 0){

        var target = document.getElementById(id.substring(8));

        dest.removeChild(target);

    }

}

document.ondragover = function(evt){

    return false;

}

document.ondrop = function(evt){

    return false;

}

案例来自:https://my.oschina.net/jiangli0502/blog/179197

相关文章

  • H5 拖放事件详解

    拖放事件 H5的拖放事件提供了多个接口: 1、drag:当元素或者选中的文本被拖动时触发(每几百毫秒触发一次),应...

  • 前端面试05:说一下 HTML5 drag api

    dragstart:事件主体是被拖放元素,在开始拖放被拖放元素时触发。 darg:事件主体是被拖放元素,在正在拖放...

  • HTML5 之 Drag

    拖放事件 HTML4 通过mousedown mousemove mouseup 来实现拖放 HTML5 拖放事件...

  • hmtl5 拖放研究

    参考文章:HTML Drag and Drop API 拖放事件 拖放事件有 dragstart, drag, d...

  • js实现拖拽事件

    拖放事件 拖放是由拖动与释放两部分组成,拖放事件也分为被拖动元素的相关事件,和容器的相关事件。 被拖动元素的相关事...

  • H5拖放异步文件上传之二——上传进度监听

      上一篇《H5拖放+FormData接口+NodeJS,完整异步文件上传(一)》,我们走通了拖放文件上传的整个流...

  • HTML5拖放

    拖放 拖放是一种常见的特效---将某个对象拖到某个位置。在H5中,任何元素都都能拖放。 实例: 亲自试一试 实例解...

  • 原生的 HTML 5 拖拽与JavaScript File AP

    W3C中关于H5拖拽(拖放)的介绍 拖放(Drag 和 drop)是 HTML5 标准的组成部分拖放是一种常见的特...

  • 一步步用HTML5动手写个图片拖拽上传预览组件

    详情参考:一步步用HTML5动手写个图片上传预览组件H5中拖拽事件有:[ - ] DragDrop:拖放完成,也就...

  • 学习要点记录

    1jq 拖放jq没有专门用于拖放的函数和事件,但是我们可以把拖放这个事件分为三个阶段。分别是点击阶段——开始准备拖...

网友评论

      本文标题:H5 拖放事件详解

      本文链接:https://www.haomeiwen.com/subject/cxbnaqtx.html