首页 > 作文

突袭HTML5之Javascript API扩展4—拖拽(Drag/Drop)概述

更新时间:2023-04-06 17:57:51 阅读: 评论:0

拖拽(drag/drop)是个非常普遍的功能。你可以抓住一个对象,并且拖动到你想放置的区域。很多javascript都类似实现了相关的功能,例如,jqueryui的draganddrop组件。在html5中,拖拽(draganddrop)成为了标准操作,任何元素都支持。正因为这个功能太普遍了,所有的主流浏览器都支持这个操作。


启用拖拽-draggable属性

非常简单,只需要将一个元素的拖动属性修改为draggable,这个元素就支持拖动了,如下所示:

复制代码 代码如下:

<imgdraggable=”true”/>

拖动中数据的传递

拖动的过程中,我们往往需要传递相应的逻辑数据来完成转换的过程,这里主要是使用datatransfer对象进行数据传递,下面先看看它的成员:

方法成员:

复制代码 代码如下:

tdata(format,data):把被拖动的数据赋值给datatransfer对象。

format:一个string型参数,指定被拖动数据的类型。该参数取值可以是“text”(文本类型)和“url”(url类型)。该参数是大小写无关的,所以传入”text”与”text”是一样的。

dat工作计划怎么写a:一个变体类型参数,指定被拖动的数据。该数据可以是文本,图片路径,url等等。

该函数有boolean类型的返回值,true表示数据成功加到datatransfer中,fal代表不成功。如果需要,可以通过这个参数来决定是否应该继续执行某些逻辑。

复制代码 代码如下:

getdata(format):获取datatransfer中存放的拖动数据。

format意义与tdata中的一样,取值可以是”text”(文本类型)和”url”(url类型)。

复制代码 代码如下:

cleardata(format):移除指定类型的数据。

这里的format除了上面可以指定的”text”(文本类型)和”url”(url类型)外,还可以取下列值:file-文件,html-html元素,image-图片。

这个方法可以用于去选择性的处理拖动的数据类型。


属性成员

复制代码 代码如下:

effectallowed:设置或获取数据源元素中的数据可以执行的操作。

属性类型为字符串,取值范围如下:

“copy”-复制数据.

“link”-链接数据.

“move”-移动数据

“copylink”-复制或链接数据,由目标对象来确定。

“copymove”-复制或移动数据,由目标对象来确定。

“linkmove”-链接或移动数据,由目标对象来确定。

“all”-所有的操作都是支持的。

“none”-禁止拖动。

“uninitialized”-默认值,采用默认的行为。

注意设置effectallowed为none以后,拖动是禁止的,但是鼠标形状还是显示没有可拖动的对象的形状,如果想不显示这个鼠标形状,则需要将window的event事件的属性returnvalue设置为fal。

复制代码 代码如下:

dropeffect:设置或获取拖动的目标上允许的操作以及相关的鼠标形状。

属性类型为字符串,取值范围如下

“copy”-鼠标显示为复制时的形状;

“link”-鼠标显示为连接的形状;

“move”-鼠标显示为移动的形状。

“none”(默认值)-鼠标显示为没有拖动的形状。

effectallowed指定了数据源支持的操作,所以通常在ondragstart事件中指定。dropeffect指定了拖动放置的目标支持的操作,所以与effectallowed配合,通常在拖动的目标上的ondragenter,ondragover和ondrop等事件中使用。

复制代码 代码如下:

files:返回拖动的文件的列表filelist。

types:ondragstart中发送的数据(被拖动的数据)类型的列表。

datatransfer对象的存在,使得在拖动的数据源和目标元素之间传递逻辑数据变成了可能。通常我们使用tdata方法在数据源元素的ondragstart事件中提供数据,然后再目标元素中,使用getdata方法获取数据。


拖动中触发的事件

下面是一次拖拽会发生的事件,基本上事件的触发顺序也就是下面的顺序:

复制代码 代码如下:

dragstart:要被拖拽的元素开始拖拽时触发,这个事件对象是被拖拽元素。

drag:拖拽元素时触发,这个事件对象是被拖拽元素。

dragenter:拖拽元素进入目标元素时触发,这个事件对象是目标元素。

dragover:拖拽某元素在目标元素上移动时触发,这个事件对象是目标元素。

dragleave:拖拽某元素离开目标元素时触发,这个事件对象是目标元素。

drop:将被拖拽元素放在目标元素内时触发,这个事件对象是目标元素。

dragend:在drop之后触发,就是拖拽完毕时触发,这个事件对象是被拖拽元素。

基本上事件的参数event都会传入相关的元素,可以很方便的进行一些修改。这里,我们并不需要处理每个事件,通常只需要挂接主要的几个事件即可。


拖动开始-ondragstart事件

从这个事件传入的参数含有的信息非常丰富,从中可以很方便的获取到被拖动的元素(event.target);从中可以设置被拖动数据(event.datatransfer.tdata);所以你可以很方便实现拖动的背后逻辑(当然你绑定的时候也可以传递其他的参数)。


拖动过程中-ondrag,ondragover,ondragenter和ondragleave事件
ondrag事件的对象是被拖拽元素,通常这个事件处理的比较少。ondragenter事件是当拖动进入当前元素时发生,ondragleave事件是在当拖动离布兰卡德开当前元素时发生,ondragover事件是在拖动在当前元素中移动时发生。

这里只需要注意一点,因为默认情况下,浏览器是禁止元素drop的,所以为了让元素可以drop,需要在这个函数中返回fal或者调用event.preventdefault()方法。如下面的例子所示。


拖动结束-ondrop,ondragend事件

当可拖动的数据被drop的时候,drop事件触发。drop结束后,dragend事件被触发,这个事件使用的也相对少一点。

看一个简单的例子:

复制代码 代码如下:

<!doctypehtml>

<html>

<head>

<scripttype=”text/javascript”>

functionallowdrop(ev){

ev.preventdefault();

}

functiondrag(ev){

ev.datatransfer.tdata(“text”,ev.target.id);

}

functiondrop(ev){

vardata=ev.datatransfer.getdata(“text”);

ev.target.appendchild(document.getelementbyid(data));

ev.preventdefault();

}

</script>

</head>

<body>

<divid=”div1″ondrop=”drop(event)”ondragover=”allowdrop(event)”></div>

<imgid=”drag1″src=”img_logo.gif”draggable=”true”ondragstart=”drag(event)”width=”336″height=”69″/>

</body>

</html>

文件拖拽

上面的例子已经使用了datatransfe瑷珲条约r的各种方法和属性,下面再看网上的另外一个有趣的应用:拖拽一个图片到网页上,然后在网页上显示。这个应用用到了datatransfer的files属性。

复制代码 代码如下:

<!doctypehtml>

<html>

<head>

<metachart=”utf-8″>

<title>html5拖放文件</title>

<style>

#ction{font-family:”georgia”,”微软雅黑”,”华文中宋”;}

.container{display:inline-block;min-height:200px;min-width:360px;color:#f30;padding:30px;border:3pxsolid#ddd;-moz-border-radius:10px;-webkit-border-radius:10px;border-radius:10px;}

.preview{max-width:360px;}

#files-list{position:absolute;lol战争学院top:0;left:500px;}

#list{width:460px;}

#list.preview{max-width:250px;}

#listp{color:#888;font-size:12px;}

#list.green{color:#09c;}

</style>

</head>

<body>

<divid=”ction”>

<p>把你的图片拖到下面的容器内:</p>

<divid=”container”class=”container”>

</div>

<divid=”files-list”>

<p>已经拖进过来的文件:</p>

<ulid=”list”></ul>

</div>

</div>

<script>

if(window.filereader){

varlist=document.getelementbyid(‘list’),

cnt=document.getelementbyid(‘container’);

//判断是否图片

functionisimage(type){

switch(type){

ca’image/jpeg’:

ca’image/png’:

ca’image/gif’:

ca’image/bmp’:

ca’image/jpg’:

returntrue;

default:

returnfal;

}

}

//处理拖放文件列表

functionhandlefilelect(evt){

evt.stoppropagation();

evt.preventdefault();

varfiles=evt.datatransfer.files;

for(vari=0,f;f=files[i];i++){

vart=f.type?f.type:’n/a’,

reader=newfilereader(),

looks=function(f,img){

list.innerhtml+='<li><strong>’+f.name+'</strong>(‘+t+

‘)-‘+f.size+’bytes<p>’+img+'</p></li>’;

cnt.innerhtml=img;

},

isimg=isimage(t),

img;

//处理得到的图片

if(isimg){

reader.onload=(function(thefile){

returnfunction(e){

img='<imgclass=”preview”src=”‘+e.target.result+'”title=”‘+thefile.name+'”/>’;

looks(thefile,img世界水电之都);

};

})(f)

reader.readasdataurl(f);

}el{

img='”o((>ω<))o”,你传进来的不是图片!!’;

looks(f,img);

}

}

}

//处理插入拖出效果

functionhandledragenter(evt){this.tattribute(‘style’,’border-style:dashed;’);}

functionhandledragleave(evt){this.tattribute(‘style’,”);}

//处理文件拖入事件,防止浏览器默认事件带来的重定向

functionhandledragover(evt){

evt.stoppropagation();

evt.preventdefault();

}

cnt.addeventlistener(‘dragenter’,handledragenter,fal);

cnt.addeventlistener(‘dragover’,handledragover,fal);

cnt.addeventlistener(‘drop’,handlefilelect,fal);

cnt.addeventlistener(‘dragleave’,handledragleave,fal);

}el{

document.getelementbyid(‘ction’).innerhtml=’你的浏览器不支持啊,同学’;

}

</script>

</body>

</html>

这个例子中使用了html5中的文件读取api:filereader对象;该对象提供了下列异步方法用于读取文件:

1.filereader.readasbinarystring(fileblob)

以二进制的方式读取文件,result属性会包含一个文件的二进制的格式

2.filereader.readastext(fileblob,opt_encoding)

以文本的方式读取文件,result属性将会包含一个文件的文本格式,默认解码参数是“utf-8”。

3.filereader.readasdataurl(file)

以url形式读取文件result将会包含一个文件的dataurl格式(图片通常用这种方式)。

当使用上面的方法读取文件后,会触发下列事件:

复制代码 代码如下:

onloadstart,onprogress,onabort,onerror,onload,onloadend

这些事件都很简单,需要的时候挂接就可以了。看下面的代码示例:

复制代码 代码如下:

functionstartread(){

//obtaininputelementthroughdom

varfile=document.getelementbyid(‘file’).files[0];

if(file){

getastext(file);

}

}

functiongetastext(readfile){

varreader=newfilereader();

//readfileintomemoryasutf-16

reader.readastext(readfile,”utf-16″);

//handleprogress,success,anderrors

reader.onprogress=updateprogress;

reader.onload=loaded;

reader.onerror=errorhandler;

}

functionupdateprogress(evt){

if(evt.lengthcomputable){

//evt.loadedandevt.totalareprogresventproperties

varloaded=(evt.loaded/evt.total);

if(loaded<1){

//increatheprogbarlength

//style.width=(loaded*200)+”px”;

}

}

}

functionloaded(evt){

//obtainthereadfiledata

varfilestring=evt.target.result;

//handleutf-16filedump

if(utils.regexp.ischine(filestring)){

//chinecharacters+namevalidation

}

el{

//runothercharttest

}

//xhr.nd(filestring)

}

functionerrorhandler(evt){

if(evt.target.error.name==”notreadableerr”){

//thefilecouldnotberead

}

}

这里也简单说一下:普通的文件下载使用的就是window.open方法,例如:

复制代码 代码如下:

window.open(‘http://aaa.bbbb.com/ccc.rar’,’_blank’)

实用参考:
官方文档:

一个不错的教程网站:http://html5.phphubei.com/html5/features/drapanddrop/

msdn帮助:

文件拖拽详述:

文件拖拽并上传:

文件拖拽上传完整例子:

文件下载的例子:

window.open攻略:

window.open参数:

本文发布于:2023-04-06 17:57:48,感谢您对本站的认可!

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

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

本文word下载地址:突袭HTML5之Javascript API扩展4—拖拽(Drag/Drop)概述.doc

本文 PDF 下载地址:突袭HTML5之Javascript API扩展4—拖拽(Drag/Drop)概述.pdf

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