博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HTML5 CSS3 专题 : 拖放 (Drag and Drop)
阅读量:5281 次
发布时间:2019-06-14

本文共 1415 字,大约阅读时间需要 4 分钟。

转载请标明出处:

本来准备写一个支持多图片拖拽上传的例子,但是为了更好的理解,先介绍一下HTML5的拖放。

拖放(Drag 和 drop)是 HTML5 标准的组成部分。

浏览器支持

Internet Explorer 9、Firefox、Opera 12、Chrome 以及 Safari 5 支持拖放。

被拖元素,dragElement : 

1、添加事件:ondragstart

2、添加属性:dragable

放置元素,dropElement:

1、添加事件:ondargenter , ondragover , ondragleave , ondragend ,ondrop

和mouser划入划出一类的事件很类似,字面也很好理解,不赘述了,下面会用例子来说明。 

1、页面上元素间的拖放

下面用个小例子,div间的拖放来展示,各个事件如何被触发:

        
效果图:

效果图注意看下console面板的输出:观察每个事件何时被触发。

需要注意几点:

a、ondragover中必须组织事件的默认行为,默认地,无法将数据/元素放置到其他元素中。

b、drop 事件的默认行为是以链接形式打开,所以也需要阻止其默认行为。

还有可能注意到:在拖放时,event中包含一个event.dataTransfer 对象,上例中我们使用了该对象的setData方法传递了拖动div的id,然后在drop中取得该id,并且复制了该元素添加到放置的div中。

下面介绍下该对象的其他方法:

        event.dataTransfer :

items = [object DataTransferItemList] @@
files = [object FileList] @@
types = text/plain @@
effectAllowed = all @@
dropEffect = none @@
clearData = function clearData() { [native code] } @@
getData = function getData() { [native code] } @@
setData = function setData() { [native code] } @@
setDragImage = function setDragImage() { [native code] } @@

我使用了js打印出了它所有的属性:

1、getData,setData上例已经使用了,clearData就是清除设置的数据。

2、值得注意的是files,当把操作系统中选择的一个或多个文件拖入该div中,files中会存储拖入文件的信息,然后我们通过file可以得到文件的类型,长度,内容然后实现上传。

3、setDragImage(image, x, y)用于设置鼠标移动过程中随鼠标一起移动的效果图。必须在dragstart中设置。

4、types,effectAllowed和dropEffect分别是拖入元素的类型,拖拽过程中鼠标显示的样式,我觉得可以忽略了这几个属性,一般用不到。

版权声明:本文为博主原创文章,未经博主允许不得转载。

转载于:https://www.cnblogs.com/dingxiaoyue/p/4924937.html

你可能感兴趣的文章
.NET Core开发日志——Startup
查看>>
Docker---(7)Docker安装启动RabbitMQ
查看>>
潜移默化学会WPF--绘图 学习(一) - AYUI框架 - 博客园
查看>>
Android项目实战(八):列表右侧边栏拼音展示效果
查看>>
备份链中断导致差异备份报错案例
查看>>
解决iconv函数无法转换某些中文的问题
查看>>
WCF技术剖析之十二:数据契约(Data Contract)和数据契约序列化器(DataContractSerializer)...
查看>>
WPF在XAML中Binding使用StringFormat属性
查看>>
MVC5 + EF6 + Bootstrap3 (14) 分部视图PartialView
查看>>
看看这个超级实用的一种类型——匿名类型
查看>>
网页JS获取当前地理位置(省市区)
查看>>
大数据时代:基于微软案例数据库数据挖掘知识点总结(Microsoft 聚类分析算法)...
查看>>
NSIS:使用nsWindows.nsh头文件调整窗体大小
查看>>
浅谈 IE下innerHTML导致的问题
查看>>
IntelliJ IDEA 12 创建Web项目 教程 超详细版
查看>>
利用Mono.Cecil动态修改程序集来破解商业组件(仅用于研究学习)
查看>>
Mysql
查看>>
去水印,色阶,换手中东西
查看>>
C++ Books
查看>>
JS滑动到页面底部
查看>>