拖拽功能

来源:互联网 发布:java排队叫号系统设计 编辑:程序博客网 时间:2024/05/22 03:14

参考: HTML5 drag & drop 拖拽与拖放简介

一、前面的话

HTML5提供专门的拖拽与拖放的API,以后实现这类效果就不必乱折腾了。但是,考虑到Opera浏览器似乎对此不感冒,在通用性上有待商榷,所以这里也就简单说一说。

二、相关重点

DataTransfer 对象:拖拽对象用来传递的媒介,使用一般为Event.dataTransfer。
draggable 属性:就是标签元素要设置draggable=true,否则不会有效果,例如:

<div title="拖拽我" draggable="true">列表1</div>

ondragstart 事件:当拖拽元素开始被拖拽的时候触发的事件,此事件作用在被拖曳元素上
ondragenter 事件:当拖曳元素进入目标元素的时候触发的事件,此事件作用在目标元素上
ondragover 事件:拖拽元素在目标元素上移动的时候触发的事件,此事件作用在目标元素上
ondrop 事件:被拖拽的元素在目标元素上同时鼠标放开触发的事件,此事件作用在目标元素上
ondragend 事件:当拖拽完成后触发的事件,此事件作用在被拖曳元素上
Event.preventDefault() 方法:阻止默认的些事件方法等执行。在ondragover中一定要执行preventDefault(),否则ondrop事件不会被触发。另外,如果是从其他应用软件或是文件中拖东西进来,尤其是图片的时候,默认的动作是显示这个图片或是相关信息,并不是真的执行drop。此时需要用用document的ondragover事件把它直接干掉。
Event.effectAllowed 属性:就是拖拽的效果。

三、相关实例

html结构

<ul id='drag'>  <li draggable="true">1</li>  <li draggable="true">2</li>  <li draggable="true">3</li>  <li draggable="true">4</li>  <li draggable="true">5</li></ul>

js代码

var ele;  document.querySelector('#drag').addEventListener('dragstart', function (e) {    ele = e.target;    ele.classList.add('draging');  })  document.querySelector('#drag').addEventListener('dragover', function (e) {    e.preventDefault();    if (e.target.nodeName === 'LI') {      e.target.parentNodeinsertBefore(ele, e.target);    }  })  document.querySelector('#drag').addEventListener('drop', function (e) {    ele.classList.remove('draging');  })
原创粉丝点击