首页 > 作文

详解Html5原生拖拽操作

更新时间:2023-04-03 08:15:36 阅读: 评论:0

最近的一次项目开发中用到了h5的拖拽功能,由于现有项目使用的是vue全家桶,使用了vuedragable这个插件,但是整个过程是比较痛苦的。遂决定从h5拖拽的原理开始研究,然后再将其应用到数据驱动的框架中。在h5中要想实现拖放操作,至少需要经过两个步骤:1) 将想要拖放的对象元素的draggable属性设为true(img与a元素默认允许拖放);2) 编写与拖放相关的事件处理代码。为了测试简便,我这里首先使用jquery库完成拖拽的基本功能。

1. 拖拽过程

1.1 拖动事件

当按住鼠标拖动draggable元素的时候会按照如下顺序依次触发

dragstart -> drag -> dragend

dragstart :在按住鼠标开始拖动时候触发(触发一次)drag :在按住鼠标拖动的过程触发(持续触发)dragend :在释放鼠标后触发(无论是把元素放到了有效的放置目标,还是放置到了无效的放置目标上)

1.2 放置事件

当将draggable元素元素拖动到容器中将会按照如下顺序依次触发

dragenter -> dragover -> drop

dragenter:只要有元素被拖动到放置目标上,就会触发dragenter事件
dragover:dragenter紧随其后的就是dragover事件,而且在被拖动的元素还在放置目标的范围内移动时,就会持续触发该事件。
dragleave:元素被拖出了放置目标,会触发dragleave
drop:将拖动元素放置到目标元素上的时候会激发

1.3 完整事件流

从开始拖动元素到放置元素到目标区域,将会按照如下顺序依次触发

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

2. 解决firefox对拖拽不支持的问题

如果我们直接给一个元素添加draggable属性,在chrome,opera中是可以直接进行拖拽(没有可以释放的操作(比如箭头变+号)),但是在firefox却没有反应

    <ul class="candrog">        <li draggable="true" id="1">优</li>        <li draggable="true" id="2">良</li>        <li draggable="true" id="3">中</li>        <li draggable="true" id="4">差</li>    </ul>    <script>        //没有任何js代码    </script>

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

<script>     <ul class="candrog">        <li draggable="true" id="1">优</li>        <li draggable="true" id="2">良</li>        <li draggable="true" id="3">中</li>        <li draggable="true" id="4">差</li>    </ul>    $('.candrog > li').bind('dragstart',function(event){        //firefox 必须访问用于拖拽通信的datatransfer对象        event.datatransfer.tdata("text",'1');    });</script>

3. 解决chrome,opera拖拽元素至容器中时没有显示可释放标识问题

可释放标识使用不同的操作系统可能不同,在mac chrome中出现的是一个圆形标识里面嵌入一个白色的’+’。

解决方案是为容器绑定dragover事件

     <ul class="candrog">        <li draggable="true" id="1">优</li>        <li draggable="true" id="2">良</li>        <li draggable="true" id="3">中</li>        <li draggable="true" id="4">差</li>    </ul>    <table class="datatbl">            <t匆匆读后感head>                <tr>                    <th style="width: 10%">节次/星期</th>                    <th>周一</th>                    <th>周二</th>                    <th>周三</th>                    <th>周四</th>                    <t戚继光简介h>周五</th>                </tr>            </thead>            <tbody>                <tr>                    <td>第一节</td>                    <td draggable="true" ></td>                    <td draggable="true" ></td>                    <td draggable="true" ></td>   中国100大学                 <td draggable="true" ></td>                    <td draggable="true" ></td>                </tr>                <!--此处省略-->            </tbody>    </table><script>    $('.c全国物理竞赛androg > li').bind('dragstart',function(event){        //firefox 必须访问用于拖拽通信的datatransfer对象        event.datatransfer.tdata("text",'1');    });    //google chrome,opera需要添加    $(".datatbl").bind("dragover",'td',function(e){          e.originalevent.preventdefault();      })  </script>

4. 解决放置时firefox打开新选项卡问题

使用firefox的时候如果释放了被拖拽的元素,默认浏览器将会打开一个新的选项卡,如下

这是由于drop回调函数之后浏览器执行了默认行为,通常的解决方案在拖拽容器的drop钩子中添加阻止默认事件执行以及阻止冒泡的代码。

<script>    //将元素释放到当前元素中    $('.datatbl').bind('drop','td',function(event){        console.log('+++drop');  强调句式      event.preventdefault();        event.stoppropagation();    });</script>

但是如果将draggable元素拖到其他地方,依然会导致打开新选项卡问题的出现,这时可以为所有容器添加如上代码。

5. 编写一个完整小例子

源码:

随后将对vuedraggable插件库进行学习,应用在vue框架中

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持www.887551.com。

本文发布于:2023-04-03 08:15:35,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/2379784ce92c4d287fb3134e611e820f.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:详解Html5原生拖拽操作.doc

本文 PDF 下载地址:详解Html5原生拖拽操作.pdf

标签:元素   拖动   拖拽   事件
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图