用javascript来实现动画导航效果的代码


Posted in Javascript onDecember 16, 2007

谁在用这些导航
google是个大公司,全世界都有google的脚印,韩国的google动画效果非常不错,蓝色理想论坛里已经有人挖过来了,可惜js写的太多了,那自己写一个吧?好,就这么干!
原理
小时候,总喜欢看动画片吧,动画片是怎样实现的呢?记得妈妈说是一张画一张画切换过去(啊?那一部葫芦兄弟要画多少副画啊? -_-! ),其实我们现在做的也是这样,用一个图片,这个图片里有很多个小图,来显示动画轨迹.按时间来移动图片,那图片不是会动了啊?(不知道,表达清楚了没…语文很重要啊!!)
准备
我们需要一张图片,一个大脑,一张会笑的脸(不笑效果就出不来了….)!!下面是我准备的图片(ps水平有限^_^)…
用javascript来实现动画导航效果的代码
代码

我们看到上面的图片,想象下,它动起来是多么的优美啊…

css

.Gnb_btn_div{  

    width:90px;  

    height:75px;  

    overflow:hidden;  

    display:block;  

    position:absolute;  

}       

.Gnb_btn_img{  

    width:100%;  

    height:525px;  

    display:block;  

    overflow:hidden;  

    text-indent:-500px;  

}  

#gnb_btn_01 .Gnb_btn_img {  

    background-image:url(/resources/imgs/img_not_found.png)  

}

javascript
<script type="text/javascript">  

// <![CDATA[  

function GNB(_7c){  

    //初始化一些参数  

    this.iImgNum=7;            //小图片个数  

    this.iImgHeight=75;        //小图片高度  

    this.iOverSpeed=50;        //鼠标经过时候切换的时间  

    this.iOutSpeed=50;        //鼠标离开时候切换的时间  

    this.eventObj=_7c;        //取得图片对象       
    this.MouseOverFlag=false;  

    this.imageIndex=0;  

    if(this.eventObj==null){return;}  

    this.eventObj.parentClass=this;this.eventAssign();  

}       

GNB.prototype.eventAssign=function(){//注册事件  

    this.eventObj.onmouseover=this.menuMouseOver;  

    this.eventObj.onmouseout=this.menuMouseOut;  

};       

GNB.prototype.menuMouseOver=function(){//鼠标经过  

    if(this.parentClass.MouseOverFlag!=false){return;}  

    this.parentClass.MouseOverFlag=true;  

    this.parentClass.clearTimeOut();  

    this.parentClass.menuMouseOverTimer();  

};       

GNB.prototype.menuMouseOut=function(){//鼠标离开  

    this.parentClass.MouseOverFlag=false;  

    this.parentClass.clearTimeOut();  

    this.parentClass.menuMouseOutTimer();  

};       

GNB.prototype.menuMouseOverTimer=function(){//经过图片位置递增  

    var _7d=this;  

    if(this.imageIndex>=this.iImgNum){return;}  

    this.eventObj.scrollTop=this.imageIndex*this.iImgHeight;  

    this.imageIndex++;  

    this.setTimerID=setTimeout(function(){_7d.menuMouseOverTimer();},this.iOverSpeed);  

};       

GNB.prototype.menuMouseOutTimer=function(){////经过图片位置递减  

    var _7e=this;if(this.imageIndex<0){return;}  

    this.eventObj.scrollTop=this.imageIndex*this.iImgHeight;  

    this.imageIndex--;  

    this.setTimerID=setTimeout(function(){_7e.menuMouseOutTimer();},this.iOutSpeed);  

};       

GNB.prototype.clearTimeOut=function(){//取消定时  

    clearTimeout(this.setTimerID);  

};  

// ]]>  

</script>

xhtml
<div class="Gnb_btn_div" id="gnb_btn_01">  

<a class="Gnb_btn_img" href="#1" href="#1">找朋友</a>  

</div>       

<script type="text/javascript">  

// <![CDATA[  

var GNB1=new GNB(document.getElementById("gnb_btn_01"));//实例单个按钮,当然也可以多个  

// ]]>  

</script>

演示地址
Javascript 相关文章推荐
js 颜色选择器(兼容firefox)
Mar 05 Javascript
extjs DataReader、JsonReader、XmlReader的构造方法
Nov 07 Javascript
JavaScript用select实现日期控件
Jul 17 Javascript
js+CSS实现模拟华丽的select控件下拉菜单效果
Sep 01 Javascript
jQuery 监控键盘一段时间没输入
Apr 22 Javascript
JavaScript实现页面定时刷新(定时器,meta)
Oct 12 Javascript
JavaScript数组去重的多种方法(四种)
Sep 19 Javascript
javaScript动态添加Li元素的实例
Feb 24 Javascript
React事件处理的机制及原理
Dec 03 Javascript
JS获取动态添加元素的方法详解
Jul 31 Javascript
Js和VUE实现跑马灯效果
May 25 Javascript
javascript进阶篇深拷贝实现的四种方式
Jul 07 Javascript
不用ajax实现点击文字即可编辑的方法
Dec 16 #Javascript
JS是否可以跨文件同时控制多个iframe页面的应用技巧
Dec 16 #Javascript
Javascript常用运算符(Operators)-javascript基础教程
Dec 14 #Javascript
javascript实现仿银行密码输入框效果的代码
Dec 13 #Javascript
CLASS_CONFUSION JS混淆 全源码
Dec 12 #Javascript
我见过最全的个人js加解密功能页面
Dec 12 #Javascript
文本链接逐个出现的js脚本
Dec 12 #Javascript
You might like
echo, print, printf 和 sprintf 区别
2006/12/06 PHP
一个简单的php加密解密函数(动态加密)
2013/06/19 PHP
PHP.ini中配置屏蔽错误信息显示和保存错误日志的例子
2014/05/12 PHP
php判断访问IP的方法
2015/06/19 PHP
php中二维数组排序问题方法详解
2015/08/28 PHP
详解Yaf框架PHPUnit集成测试方法
2017/12/27 PHP
Javascript的并行运算实现代码
2010/11/19 Javascript
在JavaScript中监听IME键盘输入事件
2011/05/29 Javascript
jQuery创建自定义的选择器用以选择高度大于100的超链接实例
2015/03/18 Javascript
jQuery UI设置固定日期选择特效代码分享
2015/08/27 Javascript
javascript输出AscII码扩展集中的字符方法
2016/12/26 Javascript
nodejs获取微信小程序带参数二维码实现代码
2017/04/12 NodeJs
AngularJS 中的数据源的循环输出
2017/10/12 Javascript
详解vue-cli中模拟数据的两种方法
2018/07/03 Javascript
layer.prompt使文本框为空的情况下也能点击确定的方法
2019/09/24 Javascript
JS实现鼠标按下拖拽效果
2020/07/23 Javascript
Vue ​v-model相关知识总结
2021/01/28 Vue.js
python动态加载包的方法小结
2016/04/18 Python
使用Python通过win32 COM实现Word文档的写入与保存方法
2018/05/08 Python
Python爬取商家联系电话以及各种数据的方法
2018/11/10 Python
OpenCV-Python 摄像头实时检测人脸代码实例
2019/04/30 Python
python 猴子补丁(monkey patch)
2019/06/26 Python
Python面向对象之Web静态服务器
2019/09/03 Python
Pytorch maxpool的ceil_mode用法
2020/02/18 Python
CSS3实战第一波 让我们尽情的圆角吧
2010/08/27 HTML / CSS
墨西哥购物网站:Elektra
2020/01/21 全球购物
What's the difference between deep copy and shallow copy? (深拷贝与浅拷贝有什么区别)
2015/11/10 面试题
生物技术专业研究生自荐信
2013/09/22 职场文书
自荐信的两点禁忌
2013/10/30 职场文书
2014年科室工作总结范文
2014/12/19 职场文书
团代会开幕词
2015/01/28 职场文书
永远是春天观后感
2015/06/12 职场文书
装修安全责任协议书
2016/03/22 职场文书
z-index不起作用
2021/03/31 HTML / CSS
golang 实现对Map进行键值自定义排序
2021/04/28 Golang
canvas 中如何实现物体的框选
2022/08/05 Javascript