热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaScript滑移效果

这里说的滑移其实就是减速效果,能根据设定的坐标平面移动。效果代码:


这里说的滑移其实就是减速效果,能根据设定的坐标平面移动。 
效果

5a4a68210ae073c719f49061ddd667ad26a779cb
代码:
 

DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns&#61;"http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv&#61;"Content-Type" content&#61;"text/html; charset&#61;gb2312" />
<title>滑移效果title>
<script type&#61;"text/Javascript">
var $ &#61; function (id) {
    
return "string" &#61;&#61; typeof id ? document.getElementById(id) : id;
}
;

function Event(e){
    
var oEvent &#61; document.all ? window.event : e;
    
if (document.all) {
        oEvent.pageX 
&#61; oEvent.clientX &#43; document.documentElement.scrollLeft;
        oEvent.pageY 
&#61; oEvent.clientY &#43; document.documentElement.scrollTop;
    }

    
return oEvent;
}


function addEventHandler(oTarget, sEventType, fnHandler) {
    
if (oTarget.addEventListener) {
        oTarget.addEventListener(sEventType, fnHandler, 
false);
    }
 else if (oTarget.attachEvent) {
        oTarget.attachEvent(
"on" &#43; sEventType, fnHandler);
    }
 else {
        oTarget[
"on" &#43; sEventType] &#61; fnHandler;
    }

}
;

function removeEventHandler(oTarget, sEventType, fnHandler) {
    
if (oTarget.removeEventListener) {
        oTarget.removeEventListener(sEventType, fnHandler, 
false);
    }
 else if (oTarget.detachEvent) {
        oTarget.detachEvent(
"on" &#43; sEventType, fnHandler);
    }
 else 
        oTarget[
"on" &#43; sEventType] &#61; null;
    }

}
;

var Class &#61; {
  create: 
function() {
    
return function() {
      
this.initialize.apply(this, arguments);
    }

  }

}


Object.extend 
&#61; function(destination, source) {
    
for (var property in source) {
        destination[property] 
&#61; source[property];
    }

    
return destination;
}



var Slippage &#61; Class.create();
Slippage.prototype 
&#61; {
  initialize: 
function(obj, options) {

    
this.obj &#61; $(obj);
    
this._timer &#61;null;
    
this._xs &#61; this._ys &#61; [];
    
this.X &#61; parseInt(this.obj.style.left) || 0;
    
this.Y &#61; parseInt(this.obj.style.top) || 0;
    
    
this.SetOptions(options);
    
this.Step &#61; Math.abs(this.options.Step);
    
this.Time &#61; Math.abs(this.options.Time);
    
this.Loop &#61; this.options.Loop;
    
this.Relative &#61; this.options.Relative;
    
    
this.SetPosition(this.options.X || [], this.options.Y || []);
  }
,
  
//设置默认属性
  SetOptions: function(options) {
    
this.options &#61; {//默认值
        Step:        10,//滑动变化率
        Time:        10,//滑动延时
        X:            [],//x坐标变化
        Y:            [],//y坐标变化
        Loop:        false,//是否循环
        Relative:    true//是否相对位置
    };
    Object.extend(
this.options, options || {});
  }
,
  
//
  SetPosition: function(arrX, arrY) {
    
if(arrX.length <&#61; 0 && arrX.length <&#61; 0return false;
    
else if(arrX.length <&#61; 0) arrX &#61; [0];
    
else if(arrY.length <&#61; 0) arrY &#61; [0];
    
    
this._xs &#61; arrX; this._ys &#61; arrY;
    
    
if(this.Relative){
        
for(var i in this._xs)if (i &#61;&#61; 0this._xs[0&#43;&#61; this.X; } else this._xs[i] &#43;&#61; this._xs[i-1]; } }
        
for(var i in this._ys)if (i &#61;&#61; 0this._ys[0&#43;&#61; this.Y; } else this._ys[i] &#43;&#61; this._ys[i-1]; } }
    }

    
    
this.Set();
  }
,
  
//
  Set: function() {
    
//当全部坐标指向同一个位置时会进入死循环
    if(this._xs.length <&#61; 0 && this._ys.length <&#61; 0return;
    
    
if(this._xs.length > 0this.X &#61; this._xs.shift();
    
if(this._ys.length > 0this.Y &#61; this._ys.shift();
    
    
if(this.Loop && this._xs.length > 0 && this._ys.length > 0this._xs.push(this.X);this._ys.push(this.Y); }
    
    
//$("aa").innerHTML&#43;&#61;this._ys.length&#43;"&#61;";
    this.Move(this.X, this.Y);
  }
,
  
//
  Move: function(iX, iY) {
    clearTimeout(
this._timer);

    
var iLeft &#61; parseInt(this.obj.style.left) || 0, iTop &#61; parseInt(this.obj.style.top) || 0, iLeftStep &#61; this.GetStep(iX, iLeft), iTopStep &#61; this.GetStep(iY, iTop);
    
    
if (iLeftStep &#61;&#61; 0 && iTopStep &#61;&#61; 0{
        
this.Set();
    }
 else {
        
this.obj.style.left &#61; (iLeft &#43; iLeftStep) &#43; "px"this.obj.style.top &#61; (iTop &#43; iTopStep) &#43; "px";
        
var oThis &#61; thisthis._timer &#61; setTimeout(function(){ oThis.Move(iX, iY); }this.Time);
    }

  }
,
  
//
  GetStep: function(iTarget, iNow) {
    
var iStep &#61; (iTarget - iNow) / this.Step;
    
if (iStep &#61;&#61; 0return 0;
    
if (Math.abs(iStep) < 1return (iStep > 0 ? 1 : -1);
    
return iStep;
  }

}
;

window.onload 
&#61; function(){
    
new Slippage("idSlippage3"{ X: [200,200,0,-200,-100,-100], Y: [0,0,100,-100,100,-100], Loop: true });
    
    
var oSlippage &#61; new Slippage("idSlippage");
    $(
"aa").onclick &#61; function(e)var oEvent &#61; Event(e);oSlippage.Move(oEvent.pageX, oEvent.pageY);}
    
    
var oSlippage2 &#61; new Slippage("idSlippage2"{ Step: 1, Relative: false }),x&#61;[],y&#61;[];
    $(
"bb").onmousedown &#61; function(e){ addEventHandler(this"mousemove", Set); }
    $(
"bb").onmouseout &#61; function(e){ removeEventHandler(this"mousemove", Set); x&#61;y&#61;[];}
    $(
"bb").onmouseup &#61; function(e){ removeEventHandler(this"mousemove", Set); oSlippage2.SetPosition(x, y);x&#61;y&#61;[];}
    
function Set(e)var oEvent &#61; Event(e); x.push(oEvent.pageX); y.push(oEvent.pageY); }
}


script>
head>
<body>
自动滑移:
<div id&#61;"cc" style&#61;"height:200px; width:500px; border:1px solid #000000;  position:relative;overflow:hidden;">
  
<div id&#61;"idSlippage3" style&#61;"width:10px; height:10px; background:#000000; position:absolute; z-index:99; top:50px; left:50px;"> div>
div>
定点滑移:&#xff08;鼠标点击&#xff09;
<div id&#61;"aa" style&#61;"height:200px; width:500px; border:1px solid #000000; overflow:hidden;">
  
<div id&#61;"idSlippage" style&#61;"width:10px; height:10px; background:#000000; position:absolute; z-index:99; top:-50px; left:50px;"> div>
div>
定线滑移:&#xff08;鼠标拖动轨迹&#xff09;
<div id&#61;"bb" style&#61;"height:200px; width:500px; border:1px solid #000000; overflow:hidden;">
  
<div id&#61;"idSlippage2" style&#61;"width:10px; height:10px; background:#000000; position:absolute; z-index:99; top:-50px; left:50px;"> div>
div>
body>
html>


本文转自博客园cloudgamer的博客&#xff0c;原文链接&#xff1a;Javascript 滑移效果&#xff0c;如需转载请自行联系原博主。



推荐阅读
  • 深入探索HTTP协议的学习与实践
    在初次访问某个网站时,由于本地没有缓存,服务器会返回一个200状态码的响应,并在响应头中设置Etag和Last-Modified等缓存控制字段。这些字段用于后续请求时验证资源是否已更新,从而提高页面加载速度和减少带宽消耗。本文将深入探讨HTTP缓存机制及其在实际应用中的优化策略,帮助读者更好地理解和运用HTTP协议。 ... [详细]
  • 本文详细介绍了一种利用 ESP8266 01S 模块构建 Web 服务器的成功实践方案。通过具体的代码示例和详细的步骤说明,帮助读者快速掌握该模块的使用方法。在疫情期间,作者重新审视并研究了这一未被充分利用的模块,最终成功实现了 Web 服务器的功能。本文不仅提供了完整的代码实现,还涵盖了调试过程中遇到的常见问题及其解决方法,为初学者提供了宝贵的参考。 ... [详细]
  • 在Java Web服务开发中,Apache CXF 和 Axis2 是两个广泛使用的框架。CXF 由于其与 Spring 框架的无缝集成能力,以及更简便的部署方式,成为了许多开发者的首选。本文将详细介绍如何使用 CXF 框架进行 Web 服务的开发,包括环境搭建、服务发布和客户端调用等关键步骤,为开发者提供一个全面的实践指南。 ... [详细]
  • Flutter 2.* 路由管理详解
    本文详细介绍了 Flutter 2.* 中的路由管理机制,包括路由的基本概念、MaterialPageRoute 的使用、Navigator 的操作方法、路由传值、命名路由及其注册、路由钩子等。 ... [详细]
  • 本文总结了一些开发中常见的问题及其解决方案,包括特性过滤器的使用、NuGet程序集版本冲突、线程存储、溢出检查、ThreadPool的最大线程数设置、Redis使用中的问题以及Task.Result和Task.GetAwaiter().GetResult()的区别。 ... [详细]
  • 详解 Qt 串口通信程序全程图文 (4)
    Qt串口通信程序全程图文是本文介绍的内容,本文一开始先讲解对程序的改进,在文章最后将要讲解一些重要问题。1、在窗口中加入一些组合框ComboBox&# ... [详细]
  • 在尝试对 QQmlPropertyMap 类进行测试驱动开发时,发现其派生类中无法正常调用槽函数或 Q_INVOKABLE 方法。这可能是由于 QQmlPropertyMap 的内部实现机制导致的,需要进一步研究以找到解决方案。 ... [详细]
  • 本文详细解析了使用C++实现的键盘输入记录程序的源代码,该程序在Windows应用程序开发中具有很高的实用价值。键盘记录功能不仅在远程控制软件中广泛应用,还为开发者提供了强大的调试和监控工具。通过具体实例,本文深入探讨了C++键盘记录程序的设计与实现,适合需要相关技术的开发者参考。 ... [详细]
  • Java Socket 关键参数详解与优化建议
    Java Socket 的 API 虽然被广泛使用,但其关键参数的用途却鲜为人知。本文详细解析了 Java Socket 中的重要参数,如 backlog 参数,它用于控制服务器等待连接请求的队列长度。此外,还探讨了其他参数如 SO_TIMEOUT、SO_REUSEADDR 等的配置方法及其对性能的影响,并提供了优化建议,帮助开发者提升网络通信的稳定性和效率。 ... [详细]
  • 使用 ListView 浏览安卓系统中的回收站文件 ... [详细]
  • 优化后的标题:深入探讨网关安全:将微服务升级为OAuth2资源服务器的最佳实践
    本文深入探讨了如何将微服务升级为OAuth2资源服务器,以订单服务为例,详细介绍了在POM文件中添加 `spring-cloud-starter-oauth2` 依赖,并配置Spring Security以实现对微服务的保护。通过这一过程,不仅增强了系统的安全性,还提高了资源访问的可控性和灵活性。文章还讨论了最佳实践,包括如何配置OAuth2客户端和资源服务器,以及如何处理常见的安全问题和错误。 ... [详细]
  • C++ 异步编程中获取线程执行结果的方法与技巧及其在前端开发中的应用探讨
    本文探讨了C++异步编程中获取线程执行结果的方法与技巧,并深入分析了这些技术在前端开发中的应用。通过对比不同的异步编程模型,本文详细介绍了如何高效地处理多线程任务,确保程序的稳定性和性能。同时,文章还结合实际案例,展示了这些方法在前端异步编程中的具体实现和优化策略。 ... [详细]
  • Python 程序转换为 EXE 文件:详细解析 .py 脚本打包成独立可执行文件的方法与技巧
    在开发了几个简单的爬虫 Python 程序后,我决定将其封装成独立的可执行文件以便于分发和使用。为了实现这一目标,首先需要解决的是如何将 Python 脚本转换为 EXE 文件。在这个过程中,我选择了 Qt 作为 GUI 框架,因为之前对此并不熟悉,希望通过这个项目进一步学习和掌握 Qt 的基本用法。本文将详细介绍从 .py 脚本到 EXE 文件的整个过程,包括所需工具、具体步骤以及常见问题的解决方案。 ... [详细]
  • 本文探讨了使用JavaScript在不同页面间传递参数的技术方法。具体而言,从a.html页面跳转至b.html时,如何携带参数并使b.html替代当前页面显示,而非新开窗口。文中详细介绍了实现这一功能的代码及注释,帮助开发者更好地理解和应用该技术。 ... [详细]
  • 本文介绍了如何利用 Delphi 中的 IdTCPServer 和 IdTCPClient 控件实现高效的文件传输。这些控件在默认情况下采用阻塞模式,并且服务器端已经集成了多线程处理,能够支持任意大小的文件传输,无需担心数据包大小的限制。与传统的 ClientSocket 相比,Indy 控件提供了更为简洁和可靠的解决方案,特别适用于开发高性能的网络文件传输应用程序。 ... [详细]
author-avatar
周周ZHOUZHOUZHOU
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有