栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

html5实现拖放操作小案例-超实用!

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

html5实现拖放操作小案例-超实用!


拖放
拖放是一种常见的特性,即抓取对象以后拖到另一个位置。在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放。拖放(Drag 和 drop)是 HTML5 标准的组成部分。

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

被拖元素,dragElement :
1、添加事件:ondragstart
2、添加属性:dragable
放置元素,dropElement:
添加事件:ondargenter , ondragover , ondragleave , ondragend ,ondrop
和mouser划入划出一类的事件很类似,字面也很好理解,不赘述了,下面会用例子来说明。

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

  
  
  
      
      

      

 #dropEle  
 div  
 {  
     float: left;  
 }  

      

      

      

  
  

  

  

  

  
 

效果图:

效果图注意看下console面板的输出:观察每个事件何时被触发。
需要注意几点:
a、ondragover中必须组织事件的默认行为,默认地,无法将数据/元素放置到其他元素中。
b、drop 事件的默认行为是以链接形式打开,所以也需要阻止其默认行为。
还有可能注意到:在拖放时,event中包含一个event.dataTransfer 对象,上例中我们使用了该对象的setData方法传递了拖动div的id,然后在drop中取得该id,并且复制了该元素添加到放置的div中。
下面介绍下该对象的其他方法:
event.dataTransfer :
items = [object DataTransferItemList] @@drag_drop.html:44
files = [object FileList] @@drag_drop.html:44
types = text/plain @@drag_drop.html:44
effectAllowed = all @@drag_drop.html:44
dropEffect = none @@drag_drop.html:44
clearData = function clearData() { [native code] } @@drag_drop.html:44
getData = function getData() { [native code] } @@drag_drop.html:44
setData = function setData() { [native code] } @@drag_drop.html:44
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分别是拖入元素的类型,拖拽过程中鼠标显示的样式,我觉得可以忽略了这几个属性,一般用不到。

本文转载自:http://blog.csdn.net/lmj623565791/article/details/31413767

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/243445.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号