
关于HTML5中的拖放
拖放(Drag 和 Drop)是一种常见的特性,即抓取对象以后拖到另一个位置,在 HTML5 中,拖放是标准的组成部分。在HTML5中用户可以使用鼠标选择一个可拖动元素,将元素拖动到一个可放置元素,并通过释放鼠标按钮放到这些元素。在拖动 *** 作期间,可拖动元素的半透明表示跟随鼠标指针。
如果我们希望元素可以被拖动,那么需要将其 draggable属性设为true (a标签draggable默认是true)
拖放的事件
在进行拖放 *** 作的不同阶段会触发数种事件,拖拽事件的dataTransfer属性存放了拖放 *** 作中的相关数据。
(在拖拽的时候只会触发拖拽的相关事件,鼠标事件,例如mousemove,是不会触发的)
DataTransfer 对象
在处理拖放 *** 作时,我们需要用到 DataTransfer 对象来保存被拖动的数据。 DataTransfer 可以保存一项或多项数据、一种或者多种数据类型。
属性
[String]指定实际的放置效果,可能的值:
copy: 复制到新的位置
move: 移动到新的位置
link: 建立一个源位置到新位置的链接
none: 禁止放置(禁止任何 *** 作)
copy: 复制到新的位置.
move:移动到新的位置 .
link:建立一个源位置到新位置的链接.
copyLink: 允许复制或者链接.
copyMove: 允许复制或者移动.
linkMove: 允许链接或者移动.
all: 允许所有的 *** 作.
none: 禁止所有 *** 作.
uninitialized: 缺省值(默认值), 相当于 all.
方法
image 要用作拖动反馈图像元素
x 图像内的水平偏移量.
y 像内的垂直偏移量.
浏览器支持
Internet Explorer 9+、Firefox、Opera 12、Chrome 以及 Safari 5+
演示代码
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Drag & Drop</title>
<style type="text/css">
.box {
display: inline-block;
width: 100px;
height: 100px;
border: 1px solid #ccccff;
background-color: #ccccff;
text-align: center;
line-height: 100px;
}
.bin {
width: 200px;
height: 200px;
padding: 10px;
border: 1px solid #ccccff;
overflow: hidden;
float: left;
}
</style>
</head>
<body>
<p style="display: table;">
<p class="bin">
<p class="box" draggable="true">可拖拽元素</p>
</p>
<p class="bin"> </p>
</p>
<script type="text/javascript">
var bins = document.querySelectorAll('.bin');
var boxs = document.querySelectorAll('.box');
var drag = null;
for (var i = 0; i < boxs.length; i++) {
var box = boxs[i];
box.onselectstart = function() {
return false;
};
box.ondragstart = function(e) {
e.dataTransfer.effectAllowed = 'move';
e.dataTransfer.setData('text/plain', e.target.outerHTML);
e.dataTransfer.setDragImage(e.target, 0, 0);
drag = this;
return true;
};
box.ondragend = function(e) {
drag = null;
return false
};
}
for (var i = 0; i < bins.length; i++) {
var bin = bins[i];
//当拖曳元素进入目标元素
bin.ondragover = function(e) {
e.preentDefault();
return true;
};
//拖拽元素在目标元素上移动
bin.ondragenter = function(e) {
this.style.backgroundColor = '#eeeeff';
return true;
};
//拖拽元素在目标元素上离开
bin.ondragleave = function(e) {
this.style.backgroundColor = '#fff';
return true;
};
//拖拽的元素在目标元素上同时鼠标放开
bin.ondrop = function(e) {
if (drag) {
drag.parentNode.removeChild(drag);
this.appendChild(drag);
}
this.style.backgroundColor = '#fff';
return false;
};
}
document.body.ondrop = function(e) {
e.preventDefault();
e.stopPropagation();
}
</script>
</body>
</html>相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
H5合成海报详解
Drag事件编辑器实现拖拽上传图片效果
以上就是H5的拖放功能详解的详细内容,
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)