• HTML5 中的拖放


    今天,给大家整理一个html5 拖放。

    首先,我们先了解一下什么是拖放?

    拖放(Drag 和 drop)是 HTML5 标准的组成部分。

    拖放是一种常见的特性,即抓取对象以后拖到另一个位置。

    在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放。

    首先介绍一下里面用到的重点知识:

    1. DataTransfer 对象:退拽对象用来传递的媒介,使用一般为Event.dataTransfer。
    2. draggable 属性:就是标签元素要设置draggable=true,否则不会有效果,例如:
    3. ondragstart 事件:当拖拽元素开始被拖拽的时候触发的事件,此事件作用在被拖曳元素上
    4. ondragenter 事件:当拖曳元素进入目标元素的时候触发的事件,此事件作用在目标元素上
    5. ondragover 事件:拖拽元素在目标元素上移动的时候触发的事件,此事件作用在目标元素上
    6. ondrop 事件:被拖拽的元素在目标元素上同时鼠标放开触发的事件,此事件作用在目标元素上
    7. ondragend 事件:当拖拽完成后触发的事件,此事件作用在被拖曳元素上
    8. Event.preventDefault() 方法:阻止默认的些事件方法等执行。在ondragover中一定要执行preventDefault(),否则ondrop事件不会被触发。另外,如果是从其他应用软件或是文件中拖东西进来,尤其是图片的时候,默认的动作是显示这个图片或是相关信息,并不是真的执行drop。此时需要用用document的ondragover事件把它直接干掉。
    9. Event.effectAllowed 属性:就是拖拽的效果。

    那现在 我们写一个简单的例子来 介绍一下:

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title></title>
    </head>

    <style type="text/css">
    #div1, #div2{
    float:left;
    198px;
    height:66px;
    margin:10px;
    padding:10px;
    border:1px solid #aaaaaa;
    }
    img{
    198px;
    height: 66px;
    }
    </style>
    <body>

    //加入图片
    <div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)">
    <img src="img/logo.png" draggable="true" ondragstart="drag(event)" id="drag1" />
    </div>
    <div id="div2" ondrop="drop(event)" ondragover="allowDrop(event)"></div>

    </body>

    <script type="text/javascript">
    function allowDrop(ev)
    {
    ev.preventDefault();
    }

    function drag(ev)
    {
    ev.dataTransfer.setData("Text",ev.target.id);
    }

    function drop(ev)
    {
    ev.preventDefault();
    var data=ev.dataTransfer.getData("Text");
    ev.target.appendChild(document.getElementById(data));
    }
    </script>
    </html>

    那我们现在来看一下具体的效果图。

    这是我们用html做出来的效果图,下面我们开始拖动:

    这是按住鼠标拖动的时候:

    松开鼠标,便完成了我们本次的执行。

     

     

    1.  
  • 相关阅读:
    jsonp的实现原理和缺点
    vue $set的使用初了解
    js将多维数组转换为一维数组
    微信小程序之页面打开数量限制
    ZOJ 1463 Brackets Sequence
    CSUOJ 1248 非变性聚丙烯酰胺凝胶电泳
    ZOJ 1524 Supermarket
    POJ 1012 Joseph
    ZOJ 1276 Optimal Array Multiplication Sequence
    POJ 1742 Coins
  • 原文地址:https://www.cnblogs.com/lixishimeng/p/6973410.html
Copyright © 2020-2023  润新知