html5指南-3.如何实现html元素拖拽功能

2016-02-19 12:14 9 1 收藏

人生本是一个不断学习的过程,在这个过程中,图老师就是你们的好帮手,下面分享的html5指南-3.如何实现html元素拖拽功能懂设计的网友们快点来了解吧!

【 tulaoshi.com - Web开发 】

本文的内容是关于在html5中如何实现html元素拖拽功能。在html5之前要实现拖拽,需要借助js,现在html5内部就支持了拖拽的功能,但是要实现稍微复杂的功能还是少不了js的帮忙。下面我们看几个例子。
1.创建拖拽对象
我们可以通过draggable属性告诉浏览器,哪些元素需要实现拖拽功能。draggable有三个值:true:元素可以被拖拽;false:元素不能被拖拽;auto:浏览器自己判断元素是否能被拖拽。
系统默认值是auto,但auto情况下浏览器对不同元素拖拽功能的支持是不一样,如:支持img对象,不支持div对象。所以,如果需要拖拽一个元素,最好还是把draggale设置为true。下面我们看一个例子:

代码如下:

!DOCTYPE HTML
html
head
titleExample/title
style
#src *
{
float: left;
}
#target, #src img
{
border: thin solid black;
padding: 2px;
margin: 4px;
}
#target
{
height: 123px;
width: 220px;
text-align: center;
display: table;
}
#target p
{
display: table-cell;
vertical-align: middle;
}
#target img
{
margin: 1px;
}
/style
/head
body
div id="src"
img draggable="true" id="car1" src="img/1.jpg" alt="" /
img draggable="true" id="car2" src="img/2.jpg" alt="" /
img draggable="true" id="car3" src="img/3.jpg" alt="" /
div id="target"
p id="msg"
drop here/p
/div
/div
script
var src = document.getElementById("src");
var target = document.getElementById("target");
/script
/body
/html

运行效果:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)
2.处理拖拽事件
现在我们来了解拖拽相关的事件,有两种类型的事件,一种是拖拽对象的事件,一种是投放区的事件。拖拽事件包括:dragstart:当元素拖拽开始触发;drag:在元素拖拽过程中触发;dragend:元素拖拽结束时触发。下面我们就看一个例子:

代码如下:

!DOCTYPE HTML
html
head
titleExample/title
style
#src *
{
float: left;
}
#target, #src img
{
border: thin solid black;
padding: 2px;
margin: 4px;
}
#target
{
height: 123px;
width: 220px;
text-align: center;
display: table;
}
#target p
{
display: table-cell;
vertical-align: middle;
}
#target img
{
margin: 1px;
}
img.dragged
{
background-color: Orange;
}
/style
/head
body
div id="src"
img draggable="true" id="car1" src="img/1.jpg" alt="" /
img draggable="true" id="car2" src="img/2.jpg" alt="" /
img draggable="true" id="car3" src="img/3.jpg" alt="" /
div id="target"
p id="msg"
drop here/p
/div
/div
script
var src = document.getElementById("src");
var target = document.getElementById("target");
var msg = document.getElementById("msg");
src.ondragstart = function (e) {
e.target.classList.add("dragged");
}
src.ondragend = function (e) {
e.target.classList.remove("dragged");
msg.innerHTML = "drop here";
}
src.ondrag = function (e) {
msg.innerHTML = e.target.id;
}
/script
/body
/html

运行效果:


3.创建投放区
我们来看投放区相关的事件:dragenter:当拖拽对象进入投放区时触发;dragover:拖拽对象在投放区内移动时触发;dragleave:拖拽对象没有投放到投放区,离开投放区的时候触发;drop:拖拽对象投放在投放区时触发。
我们来看一个例子:

代码如下:

!DOCTYPE HTML
html
head
titleExample/title
style
#src *
{
float: left;
}
#target, #src img
{
border: thin solid black;
padding: 2px;
margin: 4px;
}
#target
{
height: 123px;
width: 220px;
text-align: center;
display: table;
}
#target p
{
display: table-cell;
vertical-align: middle;
}
#target img
{
margin: 1px;
}
img.dragged
{
background-color: lightgrey;
}
/style
/head
body
div id="src"
img draggable="true" id="car1" src="img/1.jpg" alt="" /
img draggable="true" id="car2" src="img/2.jpg" alt="" /
img draggable="true" id="car3" src="img/3.jpg" alt="" /
div id="target"
p id="msg"
drop here/p
/div
/div
script
var src = document.getElementById("src");
var target = document.getElementById("target");
var msg = document.getElementById("msg");
var draggedID;
target.ondragenter = handleDrag;
target.ondragover = handleDrag;
function handleDrag(e) {
e.preventDefault();
}
target.ondrop = function (e) {
var newElem = document.getElementById(draggedID).cloneNode(false);
target.innerHTML = "";
target.appendChild(newElem);
e.preventDefault();
}
src.ondragstart = function (e) {
draggedID = e.target.id;
e.target.classList.add("dragged");
}
src.ondragend = function (e) {
var elems = document.querySelectorAll(".dragged");
for (var i = 0; i elems.length; i++) {
elems[i].classList.remove("dragged");
}
}
/script
/body
/html

运行结果:


4.使用DataTransfer
我们使用DataTransfer从拖拽对象向投放区传递数据。DataTransfer有下面的属性和方法:types:返回数据的格式;getData(format):返回指定格式数据;setData(format, data):设置指定格式数据;clearData(format):移除指定格式数据;files:返回已经投放的文件数组。 
我们来看下面的例子,他实现的效果和例3一样:

代码如下:

!DOCTYPE HTML
html
head
titleExample/title
style
#src *
{
float: left;
}
#src img
{
border: thin solid black;
padding: 2px;
margin: 4px;
}
#target
{
border: thin solid black;
margin: 4px;
}
#target
{
height: 123px;
width: 220px;
text-align: center;
display: table;
}
#target p
{
display: table-cell;
vertical-align: middle;
}
img.dragged
{
background-color: Orange;
}
/style
/head
body
div id="src"
img draggable="true" id="car1" src="img/1.jpg" alt="" /
img draggable="true" id="car2" src="img/2.jpg" alt="" /
img draggable="true" id="car3" src="img/3.jpg" alt="" /
div id="target"
p id="msg"
drop here/p
/div
/div
script
var src = document.getElementById("src");
var target = document.getElementById("target");
target.ondragenter = handleDrag;
target.ondragover = handleDrag;
function handleDrag(e) {
e.preventDefault();
}
target.ondrop = function (e) {
var droppedID = e.dataTransfer.getData("Text");
var newElem = document.getElementById(droppedID).cloneNode(false);
target.innerHTML = "";
target.appendChild(newElem);
e.preventDefault();
}
src.ondragstart = function (e) {
e.dataTransfer.setData("Text", e.target.id);
e.target.classList.add("dragged");
}
src.ondragend = function (e) {
var elems = document.querySelectorAll(".dragged");
for (var i = 0; i elems.length; i++) {
elems[i].classList.remove("dragged");
}
}
/script
/body
/html

5.拖拽文件
html5支持file api,可以让我们操作本地文件。一般我们不直接使用file api,我们可以结合其他特性一起使用,比如结合拖拽特效,如下例:

代码如下:

!DOCTYPE HTML
html
head
titleExample/title
style
body *
{
float: left;
}
#target
{
border: medium double black;
margin: 4px;
height: 75px;
width: 200px;
text-align: center;
display: table;
}
#target p
{
display: table-cell;
vertical-align: middle;
}
table
{
margin: 4px;
border-collapse: collapse;
}
th, td
{
padding: 4px;
}
/style
/head
body
div id="target"
p id="msg"
Drop Files Here/p
/div
table id="data" border="1"
/table
script
var target = document.getElementById("target");
target.ondragenter = handleDrag;
target.ondragover = handleDrag;
function handleDrag(e) {
e.preventDefault();
}
target.ondrop = function (e) {
var files = e.dataTransfer.files;
var tableElem = document.getElementById("data");
tableElem.innerHTML = "trthName/ththType/ththSize/th/tr";
for (var i = 0; i files.length; i++) {
var row = "trtd" + files[i].name + "/tdtd" + files[i].type + "/tdtd" + files[i].size + "/td/tr";
tableElem.innerHTML += row;
}
e.preventDefault();
}
/script
/body
/html

DataTransfer返回FileList对象,我们可以把他当做file数组对象,file包含下面属性:name:文件名字;type:文件类型(MIME类型);size:文件大小。
运行效果:

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


6.上传文件
下面介绍一个通过拖拽ajax上传文件的实例。

代码如下:

!DOCTYPE HTML
html
head
titleExample/title
style
.table
{
display: table;
}
.row
{
display: table-row;
}
.cell
{
display: table-cell;
padding: 5px;
}
.label
{
text-align: right;
}
#target
{
border: medium double black;
margin: 4px;
height: 50px;
width: 200px;
text-align: center;
display: table;
}
#target p
{
display: table-cell;
vertical-align: middle;
}
/style
/head
body
form id="fruitform" method="post" action="/UploadHandler.ashx"
div class="table"
div class="row"
div class="cell label"
Bananas:/div
div class="cell"
input name="bananas" value="2" //div
/div
div class="row"
div class="cell label"
Apples:/div
div class="cell"
input name="apples" value="5" //div
/div
div class="row"
div class="cell label"
Cherries:/div
div class="cell"
input name="cherries" value="20" //div
/div
div class="row"
div class="cell label"
File:/div
div class="cell"
input type="file" name="file" //div
/div
div class="row"
div class="cell label"
Total:/div
div id="results" class="cell"
items/div
/div
/div
div id="target"
p id="msg"
Drop Files Here/p
/div
button id="submit" type="submit"
Submit Form/button
/form
script type="text/javascript"
var target = document.getElementById("target");
var httpRequest;
var fileList;
target.ondragenter = handleDrag;
target.ondragover = handleDrag;
function handleDrag(e) {
e.preventDefault();
}
target.ondrop = function (e) {
fileList = e.dataTransfer.files;
e.preventDefault();
}
document.getElementById("submit").onclick = function handleButtonPress(e) {
e.preventDefault();
var form = document.getElementById("fruitform");
var formData = new FormData(form);
if (fileList) {
for (var i = 0; i fileList.length; i++) {
formData.append("file" + i, fileList[i]);
}
}
httpRequest = new XMLHttpRequest();
httpRequest.onreadystatechange = handleResponse;
httpRequest.open("POST", form.action);
httpRequest.send(formData);
}
function handleResponse() {
if (httpRequest.readyState == 4 && httpRequest.status == 200) {
var data = JSON.parse(httpRequest.responseText);
document.getElementById("results").innerHTML = "You ordered " + data.total + " items";
}
}
/script
/body
/html

效果:

上面的一些例子不同浏览器运行效果可能不同,我用的是chrome浏览器,除了例5和6不支持多文件外,其他例子运行正常。大家可以下载demo。
demo下载地址:Html5Guide.draggable.rar

来源:http://www.tulaoshi.com/n/20160219/1600287.html

延伸阅读
标签: Web开发
超文本标记语言(HTML)5 第一次向 HTML 中引入新的元素。新的结构元素包括 aside、figure 和 section。新的内联元素包括 time、meter 和 progress。新的内嵌元素有 video 和 audio。新的交互元素有 details、datagrid 和 command。 结构元素 由于缺少结构,即使是形式良好的 HTML 页面也比较难以处理。必须分析标题的级别,才能看出各个部分...
标签: Web开发
原本效果 拖拽之后效果 代码如下 代码如下: [code] !DOCTYPE HTML html head style type="text/css" #div1, #div2 {float:left; width:100px; height:35px; margin:10px;padding:10px;border:1px solid #aaaaaa;} /style script type="text/javascript" function allowDrop(ev) { ev.preventDefault(); } function drag(ev) {...
标签: Web开发
考虑我们开发一个页面的过程 : 1.设计页面的结构 - HTML:这个过程是使用各种HTML元素构建网页的结构。 2.设计页面的外观 - CSS:这个过程是使用CSS去改善网页的外观。 3.设计页面的行为 - Javascript:这个过程是给网页的元素赋予一定的行为。 上面这些除了CSS外,HTML5在另外两个方面都不同程度的进行了扩充。这个系列是集中在第一个方面。...
标签: Web开发
W3C 在 2008年 1 月 22 日发布了最新的 HTML 5 工作草案。HTML 5 工作组包括 AOL, Apple, Google, IBM, Microsoft, Mozilla, Nokia, Opera 以及数百个其他的开发商。HTML 5 中的一些新特性:嵌入音频、视频、图片的函数、客户端数据存储,以及交互式文档。其他特性包括新的页面元素,比如 header, section, footer, 以及 figure。 通过制...
标签: Web开发
今天,大多数视频是通过插件(比如 Flash)来显示的。然而,并非所有浏览器都拥有同样的插件。 HTML5 规定了一种通过 video 元素来包含视频的标准方法。 在HTML5中,video元素目前支持三种格式的视频文件, 1.Ogg = 带有 Theora 视频编码和 Vorbis 音频编码的 Ogg 文件 2.MPEG4 = 带有 H.264 视频编码和 AAC 音频编码的 MPEG 4 文件 3.Web...

经验教程

426

收藏

53
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部