html5拖曳操作 HTML5实现网页元素的拖放操作

咱_只有那么穷

咱_只有那么穷

2016-02-19 12:15

生活已是百般艰难,为何不努力一点。下面图老师就给大家分享html5拖曳操作 HTML5实现网页元素的拖放操作,希望可以让热爱学习的朋友们体会到设计的小小的乐趣。

HTML5之前,要实现网页元素的拖放操作,需要依靠mousedown、mousemove、mouseup等API,通过大量的JS代码来实现;HTML5中引入了直接支持拖放操作的API,大大简化了网页元素的拖放操作编程难度,并且这些API除了支持浏览器内部元素的拖放外,同时支持浏览器和其它应用程序之间的数据互相拖动。

本文通过一个简单示例,演示HTML5中拖放API的使用方法。

场景:

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

如下图所示,我们要实现:

通过拖放将照片从左侧相册区域拖拽到右侧垃圾箱区域;拖拽过程中,图老师健康网温馨提示部分要及时提醒,当前正在进行拖放操作;

实现方法:

如上界面的HTML代码比较简单,如下:

代码如下:

!DOCTYPE HTML
html
head
titleHTML5实现拖拽操作/title
meta charset="utf-8"/
style
.album
{
border: 3px dashed #ccc;
float: left;
margin: 10px;
min-height: 100px;
padding: 10px;
width: 220px;
}
/style
/head
body"
div id="info"
h2图老师健康网温馨提示:可将照片直接拖到垃圾箱中/h2
/div
div id="album" class="album"
h2相册/h2
img draggable="true" id="img1" src="img/bg_01.png" /
img draggable="true" id="img2" src="img/bg_02.png" /
img draggable="true" id="img3" src="img/bg_03.png" /
/div
div id="trash" class="album"
h2垃圾箱/h2
/div
br/
/body
/html

注意:如果要实现拖放操作,需要在待拖放的元素上增加draggable="true"属性;

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

接下来,再在onload事件中增加如下JS代码即可,注释比较详尽,就不再单独解释。

代码如下:

script
function init(){
var info = document.getElementById("info");
//获得被拖放的元素,本示例为相册所在的DIV
var src = document.getElementById("album");
//开始拖放操作
src.ondragstart = function (e) {
//获得被拖放的照片ID
var dragImgId = e.target.id;
//获得被拖动元素
var dragImg = document.getElementById(dragImgId);
//拖放操作结束
dragImg.ondragend = function(e){
//恢复提醒信息
info.innerHTML="h2图老师健康网温馨提示:可将照片直接拖到垃圾箱中/h2";
};
e.dataTransfer.setData("text",dragImgId);
};
//拖放过程中
src.ondrag = function(e){
info.innerHTML="h2--照片正在被拖动--/h2";
}
//获得拖放的目标元素
var target = document.getElementById("trash");
//关闭默认处理;
target.ondragenter = function(e){
e.preventDefault();
}
target.ondragover = function(e){
e.preventDefault();
}
//有东西拖放到了目标元素
target.ondrop = function (e) {
var draggedID = e.dataTransfer.getData("text");
//获取相册中的DOM对象
var oldElem = document.getElementById(draggedID);
//从相册DIV中删除该照片的节点
oldElem.parentNode.removeChild(oldElem);
//将被拖动的照片DOM节点添加到垃圾桶DIV中;
target.appendChild(oldElem);
info.innerHTML="h2图老师健康网温馨提示:可将照片直接拖到垃圾箱中/h2";
e.preventDefault();
}
}
/script

实现效果:

展开更多 50%)
分享

猜你喜欢

html5拖曳操作 HTML5实现网页元素的拖放操作

Web开发
html5拖曳操作 HTML5实现网页元素的拖放操作

Html5实现如何在两个div元素之间拖放图像

Web开发
Html5实现如何在两个div元素之间拖放图像

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

html5 标签

Web开发
html5 标签

HTML5中的新元素介绍

Web开发
HTML5中的新元素介绍

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

HTML5标签小集

Web开发
HTML5标签小集

基于HTML5超酷摄像头(HTML5 webcam)拍照功能实现代码

Web开发
基于HTML5超酷摄像头(HTML5 webcam)拍照功能实现代码

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

Java泛型编程快速入门

Java泛型编程快速入门

.NET架构的核心开发技术

.NET架构的核心开发技术
下拉加载更多内容 ↓