用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 相关文章推荐
Javascript 验证上传图片大小[客户端]
Aug 01 Javascript
JQuery验证工具类搜集整理
Jan 16 Javascript
javascript获取鼠标位置部分的实例代码(兼容IE,FF)
Aug 05 Javascript
js调试工具console.log()方法查看js代码的执行情况
Aug 08 Javascript
JavaScript中原型和原型链详解
Feb 11 Javascript
jquery序列化方法实例分析
Jun 10 Javascript
深入学习JavaScript对象
Oct 13 Javascript
整理关于Bootstrap警示框的慕课笔记
Mar 29 Javascript
BootStrap 动态表单效果
Jun 02 Javascript
vue发送ajax请求详解
Oct 09 Javascript
Mpvue中使用Vant Weapp组件库的方法步骤
May 16 Javascript
基于vue实现圆形菜单栏组件
Jul 05 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
global.php
2006/12/09 PHP
用PHP的ob_start() 控制您的浏览器cache
2009/08/03 PHP
php模板函数 正则实现代码
2012/10/15 PHP
js 动态选中下拉框
2009/11/26 Javascript
利用jquery操作select下拉列表框的代码
2010/06/04 Javascript
jQuery插件原来如此简单 jQuery插件的机制及实战
2012/02/07 Javascript
Javascript前端UI框架Kit使用指南之kitjs的对话框组件
2014/11/28 Javascript
详谈LABJS按需动态加载js文件
2015/05/07 Javascript
二维码图片生成器QRCode.js简单介绍
2017/08/18 Javascript
koa源码中promise的解读
2018/11/13 Javascript
详解从react转职到vue开发的项目准备
2019/01/14 Javascript
jQuery访问json文件中数据的方法示例
2019/01/28 jQuery
Vue开发之封装分页组件与使用示例
2019/04/25 Javascript
ES6中定义类和对象的方法示例
2019/07/31 Javascript
你不知道的 TypeScript 高级类型(小结)
2020/08/28 Javascript
在vue中实现清除echarts上次保留的数据(亲测有效)
2020/09/09 Javascript
逐行分析鸿蒙系统的 JavaScript 框架(推荐)
2020/09/17 Javascript
Python中List.count()方法的使用教程
2015/05/20 Python
详解Python中映射类型(字典)操作符的概念和使用
2015/08/19 Python
python3新特性函数注释Function Annotations用法分析
2016/07/28 Python
python安装教程 Pycharm安装详细教程
2017/05/02 Python
python里使用正则表达式的组嵌套实例详解
2017/10/24 Python
python 用lambda函数替换for循环的方法
2018/06/09 Python
react+django清除浏览器缓存的几种方法小结
2019/07/17 Python
Python 读取WAV音频文件 画频谱的实例
2020/03/14 Python
CSS3制作轮播图的一种方法
2019/11/11 HTML / CSS
驴妈妈旅游网:中国新型的B2C旅游电子商务网站
2016/08/16 全球购物
GLAMGLOW香港官网:明星出镜前的秘密武器
2017/03/16 全球购物
阿波罗盒子:Apollo Box
2017/08/14 全球购物
素质拓展感言
2014/01/29 职场文书
小学生操行评语大全
2014/04/22 职场文书
视光学专业自荐信
2014/06/24 职场文书
春节超市活动方案
2014/08/14 职场文书
Python中OpenCV实现查找轮廓的实例
2021/06/08 Python
仅仅使用 HTML/CSS 实现各类进度条的方式汇总
2021/11/11 HTML / CSS
零基础学java之带返回值的方法的定义和调用
2022/04/10 Java/Android