`
yangsp1
  • 浏览: 47628 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JavaScript 拖放效果系列三——解决快速拖拽的问题

    博客分类:
  • js
阅读更多
原文来自:http://www.cainiao8.com/web/js_examples/15_tuozhuai3.html



上一节我们让拖拽代码使用起来更方便、适用于多个元素,同时解决了偶尔会出现的拖动一个元素,多个元素一起移动的问题。但是在快速拖拽的时候,会出现延迟,或者元素干脆就停止移动了。
元素停止移动的原因

分析一下上面问题的原因:鼠标滑动地太快,自然会造成mousemove事件多次发生,相应的,事件处理函数也多次被调用,自然造成延迟。延迟之后,元素移动的速度赶不上鼠标移动的速度,可能造成鼠标移出元素的状态,从而触发了mouseout事件,从而造成了被拖动元素停止移动。

为了验证上面的想法,我们给元素添加一个onmouseout的响应函数,来显示一段字符串。修改代码如下:
<script type="text/javascript">
function dragInit(node){
	if(node.className == "drag"){ 
		……
		node.onmouseout = out;
		……
	}
		……
}
……
function out(){
	alert("鼠标一出去啦,我不能再移动啦!!");
}
……
</script>


点击进入测试页面,可以发现浏览器对mouseout十分敏感,我在IE和FF下做了测试,只要稍微移动的快一点,就会触发鼠标移出事件。但是只要在视觉上鼠标还没有移出元素,那么元素还是可以正常移动的。但是如果鼠标“看起来”移出了元素,那么拖拽效果就真的彻底被破坏了。
解决快速拖拽时元素停止移动的问题

这个问题是不可避免的吗?当然不是,如果你是豆瓣的用户,可以进入“我的豆瓣”栏目测试一下它们的拖拽功能()。就算拖拽的速度再快也不会出现“突然停止”的情况。


我们也来试着解决这个问题。上面已经分析了,造成元素停止移动的原因是鼠标移出了被拖拽的元素,造成mousemove事件无法得到响应。那么我们让 mousemove事件在有延迟的情况下仍然可以被响应就可以了,我们只要把事件处理函数加到document上就可以做到这一点了(之前也想过其它解决方案,但是失败了)。修改之后的代码如下:

<script type="text/javascript">
//使用该变量标识拖拽的元素
var dragElement = null;
……
function dragInit(node){
	if(node.className == "drag"){ 
		node.onmousedown = down;
		//使用document响应mousemove事件
		document.onmousemove = move;
		node.onmouseover = over;
		//删除该函数node.onmouseup = up;
		node.style.position = "relative";
		node.style.top = "0px";
		node.style.left = "0px";
		node.dragging = false;
	}
	var children = node.childNodes;
	for(var i = 0;i < children.length; i++){
		dragInit(children[i]);
	}
}
function down(event)
{	
……
}
function move(event){
	event = event || window.event;
	//判断dragElement是否为null,即是否为拖拽状态
	if(dragElement){
		var x,y;
		y = event.clientY - mouseY + objY;
		x = event.clientX - mouseX + objX;
		//改变dragElement的位置
		dragElement.style.top = y + "px";
		dragElement.style.left = x + "px";
	}
}
function docUp(){
	//停止拖拽
	dragElement = null;
}
……
</script>


可以在修改之后的测试页面实验一下,无论速度多快,延迟都不会造成被拖拽元素停止移动的问题。下面就解释一下主要的修改之处:

   1. 使用全局变量dragElement来标记当前拖拽元素。
   2. dragInit函数中,给document定义mouseover的响应函数。
   3. mousemove的响应函数的针对对象不再是this,而是dragElement。

JavaScript拖拽系列

   1. JavaScript拖拽
   2. JavaScript拖拽2——多元素、分离JS
   3. JavaScript拖拽3——解决快速拖拽的问题
   4. JavaScript拖拽4——获得元素的位置
   5. JavaScript拖拽5——性能优化
   6. JavaScript拖拽6——修复错误
分享到:
评论

相关推荐

    谈谈对JavaScript原生拖放的深入理解

     拖放(drag-and-drop,DnD)其实是两个动作——拖和放。所以,它涉及到两个元素。一个是被拖的元素,称为拖放源;另一个是要放的目标,称为拖放目标。本文将通过拆分这两个概念来详细介绍原生拖放 拖放源  什么样...

    accessible-drag-and-drop:扩展 HTML5 拖放功能——因此它可以处理多个元素,并支持键盘交互

    随附的代码是关于如何扩展 HTML5 拖放功能的教程 - 因此它可以处理多个元素,并支持键盘交互,供视力正常和屏幕阅读器用户使用。 该教程可以在这里找到: :

    JavaScript高级教程

    第 1 章 JavaScript 是什么...............................................1 3 1.1 历史简述..............................................1 1.2 JavaScript 实现................................................

    java源码包---java 源码 大量 实例

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    JAVA上百实例源码以及开源项目源代码

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    JAVA上百实例源码以及开源项目

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    java源码包2

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    java源码包3

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    java源码包4

     Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、火焰效果的线程、Applet的高度,图片到图片装载器、绘制火焰效果的X坐标...

    成百上千个Java 源码DEMO 4(1-4是独立压缩包)

    Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰效果 Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、...

    成百上千个Java 源码DEMO 3(1-4是独立压缩包)

    Java绘制图片火焰效果 1个目标文件 摘要:Java源码,图形操作,火焰效果 Java绘制图片火焰效果,源代码相关注释:前景和背景Image对象、Applet和绘制火焰的效果的Image对象、Applet和绘制火焰的效果的Graphics对象、...

    Eclipse_Swt_Jface_核心应用_部分19

    13.1.7 打印程序示例:打印文件后的效果预览 273 13.2 使用应用程序 274 13.3 对AWT/Swing程序的支持 275 13.4 OLE和ActiveX控件的支持 275 13.4.1 OLE控件的面板类(OleFrame) 276 13.4.2 OLE控件类...

    Ext Js权威指南(.zip.001

    1.2.4 在javascript中使用json / 4 1.2.5 在.net中使用json / 8 1.2.6 在java中使用json / 12 1.2.7 更多有关json的信息 / 15 1.3 ext js 4概述 / 15 1.4 ext js的开发工具的获取、安装与配置介绍 / 18 1.4.1...

Global site tag (gtag.js) - Google Analytics