用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 相关文章推荐
jquery鼠标滑过提示title具体实现代码
Aug 06 Javascript
JavaScript Ajax Json实现上下级下拉框联动效果实例代码
Nov 23 Javascript
jQuery判断当前点击的是第几个li的代码
Sep 26 Javascript
jquery插件jquery.nicescroll实现图片无滚动条左右拖拽的方法
Aug 10 Javascript
简单实现IONIC购物车功能
Jan 10 Javascript
原生JS轮播图插件
Feb 09 Javascript
SVG描边动画
Feb 23 Javascript
微信小程序实现实时圆形进度条的方法示例
Feb 24 Javascript
jQuery实现腾讯信用界面(自制刻度尺)样式
Aug 15 jQuery
使用Vue组件实现一个简单弹窗效果
Apr 23 Javascript
Vue.js中的extend绑定节点并显示的方法
Jun 20 Javascript
JS删除对象中某一属性案例详解
Sep 08 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
第五节 克隆 [5]
2006/10/09 PHP
通过对php一些服务器端特性的配置加强php的安全
2006/10/09 PHP
php读取excel文件的简单实例
2013/08/26 PHP
php简单的留言板与回复功能具体实现
2014/02/19 PHP
ThinkPHP实现图片上传操作的方法详解
2017/05/08 PHP
php xhprof使用实例详解
2019/04/15 PHP
常用参考资料(手册)下载或者链接
2006/07/22 Javascript
js实现上传图片预览的方法
2015/02/09 Javascript
【JS+CSS3】实现带预览图幻灯片效果的示例代码
2016/03/17 Javascript
jQuery中DOM节点的删除方法总结(超全面)
2017/01/22 Javascript
详解基于Angular4+ server render(服务端渲染)开发教程
2017/08/28 Javascript
微信小程序实现跟随菜单效果和循环嵌套加载数据
2017/11/21 Javascript
JavaScript运行原理分析
2018/02/09 Javascript
Bootstrap Paginator+PageHelper实现分页效果
2018/12/29 Javascript
layui使用label标签的方法
2019/09/14 Javascript
微信小程序scroll-view锚点链接滚动跳转功能
2019/12/12 Javascript
微信小程序实现一个简单swiper代码实例
2019/12/30 Javascript
开发Node CLI构建微信小程序脚手架的示例
2020/03/27 Javascript
python数据库操作常用功能使用详解(创建表/插入数据/获取数据)
2013/12/06 Python
numpy 对矩阵中Nan的处理:采用平均值的方法
2018/10/30 Python
Python编程实现tail-n查看日志文件的方法
2019/07/08 Python
tensorflow模型转ncnn的操作方式
2020/05/25 Python
python3中for循环踩过的坑记录
2020/12/14 Python
英国工作场所设备购买网站:Slingsby
2019/05/03 全球购物
FirstCry阿联酋儿童和婴儿产品网上购物:FirstCry.ae
2021/02/22 全球购物
System.Array.CopyTo()和System.Array.Clone()有什么区别
2016/06/20 面试题
简历中个人自我评价范文
2013/12/26 职场文书
旅行社各个岗位职责
2014/03/15 职场文书
2014年学校国庆主题活动方案
2014/09/16 职场文书
大学生党员自我剖析材料
2014/10/06 职场文书
2015年科研工作总结范文
2015/05/13 职场文书
工会经费申请报告
2015/05/15 职场文书
学习计划是什么
2019/04/30 职场文书
CSS3 实现NES游戏机的示例代码
2021/04/21 HTML / CSS
Django与数据库交互的实现
2021/06/03 Python
MySQL中一条SQL查询语句是如何执行的
2022/04/08 MySQL