如何使用HTML5实现多个元素的拖放功能


本文摘自PHP中文网,作者不言,侵删。

通过使用HTML5的拖放功能我们可以拖放HTML页面元素。在上一篇文章中,我们介绍了有关于可以拖放单个元素的代码。在接下来的这篇文章中,我们将来介绍关于允许拖放多个元素的代码。

HTML5拖放

话不多说,我们直接看示例

示例一:使用UL标记拖放多个元素

代码如下:

ListDragDrop.html

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

<!DOCTYPE html>

<html>

<head>

    <meta charset="utf-8" />

    <title></title>

  <link rel="stylesheet" href="ListDragDrop.css"/>

  <script>

    function load() {     

      var delbox = document.getElementById('del');

      delbox.addEventListener('dragover', onDragOver, false);

      delbox.addEventListener('drop', onDrop, false);     

      var elems = document.querySelectorAll('ul#list1 > li');     

      for (var i = 0; i < elems.length; i++) {

        el = elems[i];

        el.setAttribute('draggable', 'true');

        el.addEventListener('dragstart', onDragStart, false);

      }

    }   

function onDragStart(e) {

      e.dataTransfer.effectAllowed = 'copy';

      e.dataTransfer.setData('text', this.id);

    }   

function onDragOver(e) {

      e.preventDefault();

    }   

function onDrop(e) {

      if (e.stopPropagation) e.stopPropagation();     

      var eid = e.dataTransfer.getData('text');     

      var elem = document.getElementById(eid);

      elem.parentNode.removeChild(elem);

    

</script>

</head>

<body onload="load();">

   <div id="del">删除</div>

    <ul id="list1">

      <li id="1">海豚</li>

      <li id="2">鲸鱼</li>

      <li id="3">企鹅</li>

      <li id="4">北极熊</li>

      <li id="5">雪狐</li>

    </ul>

    </ul>

</body>

</html>

ListDragDrop.css

1

2

3

4

5

6

7

8

9

10

#del{

  width:120px

  height:60px

  border: solid 2px #ff6a00;

  }

ul#list1 > li {

  display: block

  width: 150px

  border: 1px solid #808080;

  }

说明:

阅读剩余部分

相关阅读 >>

如何使用html5实现多个元素的拖放功能

更多相关阅读请进入《HTML5拖放》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...