IE/FireFox具备兼容性的拖动代码_javascript技巧
作者:金子祺_475 | 来源:互联网 | 2018-05-05 00:27
IEFireFox具备兼容性的拖动代码
特点: 1、兼容 IE6、FF、Opear(IE7还没有机会测试) 2、拖动流畅 3、起点与终点之间有过渡,使移动更平滑(可调) 演示 /* Author:misshjn HomePage:http://www.happyshow.org Date:2007-04-30 拖动开始 */ function _getStyle(element,styleProp){ if (element.currentStyle){ var y = element.currentStyle[styleProp]; }else if (window.getComputedStyle){ var y = document.defaultView.getComputedStyle(element,null).getPropertyValue(styleProp.replace(/([A-Z])/g,"-$1").toLowerCase()); } return y; } function _elementOnmouseDown(evt,blockID){ var obj, temp; obj=document.getElementById(blockID); var x = evt.clientX || evt.pageX; var y = evt.clientY || evt.pageY; obj.startX=x-obj.offsetLeft; obj.startY=y-obj.offsetTop; var d = document.createElement("p"); d.style.position = "absolute"; d.style.width = obj.clientWidth + parseInt(_getStyle(obj,"borderLeftWidth"),10) + parseInt(_getStyle(obj,"borderRightWidth")) -2 + "px"; d.style.height = obj.clientHeight + parseInt(_getStyle(obj,"borderTopWidth"),10) + parseInt(_getStyle(obj,"borderBottomWidth")) -2 + "px"; d.style.border = "1px dashed #666"; d.style.top = _getStyle(obj,"top"); d.style.left = _getStyle(obj,"left"); d.style.zIndex = "9999"; document.body.appendChild(d); document.Onmousemove=function(evt){ d.style.left= (evt?evt.pageX:event.clientX) - obj.startX + "px"; d.style.top= (evt?evt.pageY:event.clientY) - obj.startY + "px"; }; document.Onmouseup=function(){ var objL = parseInt(_getStyle(obj,"left"),10); var objT = parseInt(_getStyle(obj,"top"),10); var obj2L = parseInt(d.style.left,10); var obj2T = parseInt(d.style.top,10); var todolist = []; var level = 10; //元素移动从起点到终点之间过渡的级数,大于0的整数 var speed = 10; //毫秒,每次移动的间隔时间,数字越大,动画感越强,但跳跃感也越大 for (i=1; i<=level; i++){ todolist.push(function(t){ setTimeout(function(){ obj.style.left = objL + (obj2L-objL)*(t/level) + "px"; obj.style.top = objT + (obj2T-objT)*(t/level) + "px"; if(t==i)todolist=null; },speed*arguments[0]); }); } for (i=1; i<=level; i++){ todolist[i-1](i); } document.body.removeChild(d); document.Onmousemove= null; document.Onmouseup= null; }; } /* 拖动结束 */
推荐阅读
本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ...
[详细]
蜡笔小新 2024-12-25 13:17:38
本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ...
[详细]
蜡笔小新 2024-12-25 11:31:48
本文详细介绍如何通过设置SSH密钥来获取连接GitHub远程仓库的权限,包括生成密钥、添加到GitHub账户以及验证连接等步骤。 ...
[详细]
蜡笔小新 2024-12-19 19:02:13
本文介绍如何配置SecureCRT以正确显示Linux终端的颜色,并解决中文显示问题。通过简单的步骤设置,可以显著提升使用体验。 ...
[详细]
蜡笔小新 2024-12-19 18:30:14
最新计算机专业原创毕业设计参考选题都有源码+数据库是近期作品ling取参考你的选题刚好在下面有,有时间看到机会给您发1ssm资源循环利用2springboot校园考勤系统3ssm防 ...
[详细]
蜡笔小新 2024-12-19 11:39:56
本文介绍如何在 CentOS 7.2 系统上配置防火墙以开放特定的服务端口,包括 FTP 服务的临时与永久开放方法,以及如何验证配置是否生效。 ...
[详细]
蜡笔小新 2024-12-18 20:58:47
本指南详细介绍了如何在同一台计算机上配置多个GitHub账户,并使用不同的SSH密钥进行身份验证,确保每个账户的安全性和独立性。 ...
[详细]
蜡笔小新 2024-12-18 10:54:08
本文详细介绍了一款名为WinSCP的开源图形化SFTP客户端,该工具支持SSH协议,适用于Windows操作系统,能够实现与Linux系统之间的文件传输。对于从事嵌入式开发的技术人员来说,掌握WinSCP的使用方法将极大提高工作效率。 ...
[详细]
蜡笔小新 2024-12-18 09:58:05
本文探讨了一种常见的网络配置问题及其解决方案,即如何在外网环境下安全地访问位于局域网内的计算机。特别介绍了使用SSH反向隧道技术来实现这一目标的具体步骤和注意事项。 ...
[详细]
蜡笔小新 2024-12-18 09:02:41
本文详细介绍了如何在Linux系统上搭建Web服务器的过程,包括安装Apache、PHP和MySQL等关键组件,以及遇到的一些常见问题及其解决方案。 ...
[详细]
蜡笔小新 2024-12-17 19:02:43
本文详细介绍了如何通过Git Bash在本地仓库与远程仓库之间建立连接并进行同步操作,包括克隆仓库、提交更改和推送更新等步骤。 ...
[详细]
蜡笔小新 2024-12-17 17:41:27
本文详细介绍了如何在 Windows 系统中安装 Git 工具,并通过配置 SSH 密钥实现与 GitHub 的安全连接。包括下载、安装、环境配置及验证连接等关键步骤。 ...
[详细]
蜡笔小新 2024-12-17 16:22:46
本文详细探讨了如何通过指令安全、端口管理和SSL代理等措施有效保护Redis服务的安全性。 ...
[详细]
蜡笔小新 2024-12-17 13:18:07
本文介绍如何在Django项目中集成和使用xAdmin,这是一个增强版的管理界面,提供了比Django默认admin更多的功能。文中详细描述了集成步骤及配置方法。 ...
[详细]
蜡笔小新 2024-12-17 10:14:08
本文介绍了Java语言开发的远程教学系统,包括源代码、MySQL数据库配置以及相关文档,适用于计算机专业的毕业设计。系统支持远程调试,采用B/S架构,适合现代教育需求。 ...
[详细]
蜡笔小新 2024-12-17 05:12:29