允许拖动      

在Html5中,<img.../>元素默认就是可拖动的;而<a.../>元素只要设置了href属性也是可以拖动的。

而对于普通元素而言,如果需要将其变为可拖动的,只需将该元素的draggable属性设为true即可。但仅仅只设置该属性还不够,因为该属性只表示该元素可以拖动,可是并未携带任何数据,所以用户无法看到拖动效

为了让拖动操作能携带数据,应该为被拖动元素的ondragstart事件指定监听器,在该监听器中让拖动操作可以携带数据。

拖曳释放HTML5 html拖放api_拖曳释放HTML5

 允许拖放

从以上代码运行结果中可以发现,无论是拖动图片还是div,拖动时都显示一个“禁止”标志,这说明就算目标被拖到“目标地点”,“目的地”却并不接受该元素——因为当被拖动元素被“拖过”document对象时,document对象阻止了默认的拖动事件,而其他HTML组件也是位于document对象内的,因此他们也不能接受放。

为了达到"放"的目标,我们应该为document的ondragover事件指定监听器,在监听器中取消document对拖动事件的默认行为。

拖曳释放HTML5 html拖放api_监听器_02

请注意:

不同浏览器对于拖放操作的默认动作并不相同,例如:当用户将HTML元素拖到指定位置释放后,Firefox浏览器会默认打开一个新的页面,页面的URL为拖放操作携带的数据。但当使用Chrome浏览器执行该操作,Chrome浏览器未执行任何默认动作。

若我们想要取消拖放操作的默认行为,则可以为document的ondrop事件绑定监听器。

拖曳释放HTML5 html拖放api_拖放_03

下面页面代码实现了一个可以自由拖放的<div/>元素。

拖曳释放HTML5 html拖放api_HTML图片_04

在为document的ondrop事件绑定监听器的代码中,将<div/>元素的left属性设为evt事件发生点的X坐标,top属性设为evt事件发生点的Y坐标。这样就可以将<div/>元素移动到指定位置。