突袭HTML5之Javascript API扩展4—拖拽(Drag/Drop)概述
来源: 阅读:1254 次 日期:2016-07-22 14:47:48
温馨提示: 小编为您整理了“突袭HTML5之Javascript API扩展4—拖拽(Drag/Drop)概述”,方便广大网友查阅!

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

启用拖拽-draggable属性

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

代码如下:

拖动中数据的传递

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

方法成员:

代码如下:

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

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

data:一个变体类型参数,指定被拖动的数据。该数据可以是文本,图片路径,URL等等。

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

代码如下:

getData(format):获取dataTransfer中存放的拖动数据。

format意义与setData中的一样,取值可以是"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设置为false。

代码如下:

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

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

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

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

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

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

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

代码如下:

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

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

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

拖动中触发的事件

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

代码如下:

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

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

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

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

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

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

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

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

拖动开始-ondragstart事件

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

拖动过程中-ondrag,ondragover,ondragenter和ondragleave事件

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

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

拖动结束-ondrop,ondragend事件

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

看一个简单的例子:

代码如下:

functionallowDrop(ev){

ev.preventDefault();

}

functiondrag(ev){

ev.dataTransfer.setData("Text",ev.target.id);

}

functiondrop(ev){

vardata=ev.dataTransfer.getData("Text");

ev.target.appendChild(document.getElementById(data));

ev.preventDefault();

}

Baidu
map

文件拖拽

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

代码如下:

HTML5拖放文件

把你的图片拖到下面的容器内:

已经拖进过来的文件:

Baidu
map

这个例子中使用了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.totalareProgressEventproperties

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

if(loaded<1){

//Increasetheprogbarlength

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

}

}

}

functionloaded(evt){

//Obtainthereadfiledata

varfileString=evt.target.result;

//HandleUTF-16filedump

if(utils.regexp.isChinese(fileString)){

//ChineseCharacters+Namevalidation

}

else{

//runothercharsettest

}

//xhr.send(fileString)

}

functionerrorHandler(evt){

if(evt.target.error.name=="NotReadableErr"){

//Thefilecouldnotberead

}

}

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

代码如下:

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

更多信息请查看 网页制作
【点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】 【点此处查询各地各类考试咨询QQ号码及交流群】
上一篇: 突袭HTML5之Javascript API扩展5—其他扩展(应用缓存/服务端消息/桌面通知)
下一篇: 突袭HTML5之Javascript API扩展3—本地存储全新体验
手机网站地址: 突袭HTML5之Javascript API扩展4—拖拽(Drag/Drop)概述
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
相关阅读 网页制作
使用CSS制作立体导航栏 10月30日
用纯CSS3实现网页中常见的小箭头 10月30日
有关HTML5中背景音乐的自动播放功能 10月30日
HTML5、Select下拉框右边加图标的实现代码(增进用户体验) 10月30日
html5实现图片转圈的动画效果——让页面动起来 10月30日
html5清空画布方法(三种) 10月30日
HTML实现移动端固定悬浮半透明搜索框 10月30日
HTML5 文件域+FileReader 分段读取文件并上传到服务器 10月30日
Dreamweaver怎么设计彩色边框的表格? 10月30日
Dreamweaver怎么给个人简历添加照片并排版? 10月30日
基于HTML5的WebGL实现json和echarts图表展现在同一个界面 10月30日
解决HTML5手机端页面缩放的问题 10月30日
利用纯CSS实现居中的七大方法示例 09月29日
CSS3中伪元素::before和::after的用法示例 09月29日
详解使用 CSS 的 font-size-adjust 属性改善网页排版 09月29日
HTML5+CSS3 实现灵动的动画 TAB 切换效果(DEMO) 09月29日
css3 pointer-events 介绍详解 09月29日
CSS :focus-within的具体使用 09月29日
你所不知道的 CSS 动画技巧与细节 09月29日
详解CSS3选择器:nth-child和:nth-of-type之间的差异 09月29日
最新信息
公考类
招聘类
各类考试
关于我们| 联系我们| 人才招聘| 网站声明| 网站帮助| 非正式的简要咨询| 简要咨询须知| 加入群交流| 手机站点| 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00) 版权所有:
云南网警报警专用图标
Baidu
map