代码改变世界

也实现一个首页图片幻灯效果

2008-07-04 13:16  BAsil  阅读(3335)  评论(13编辑  收藏  举报

前几天,在园子里看了一个图片幻灯效果,很不错,不过今天想找却找不到了。这两天想把网站的图片幻灯效果给换了,原来的虽然做成了web控件,不过控件里硬编码了javascript和css,甚至还有document.write这样的输出,感觉很是不爽。偶然发现了一篇翻译文章如何使用 JavaScript 创建可维护的幻灯片效果,感觉原作者在构建可分离的javascript和css上颇有心得,原文的效果http://www.planabc.net/demo/slideshow/












不过这里和我想要的效果还有些差异,参照大部分国内网站的实现方式,应该能够实现定时的播放,同时在右下角还应该有一个序列号的指示,就像新浪网的首页那样,既然作者帮我们作了大部分的分离工作,剩下的这部分自己实现,也十分简单。
下面给出代码,在代码中我会把新加入的部分作出说明

tools.js


addEvent的使用是为了避免IE的this指向总是window,而用obj[type+fn] = function(){obj['e'+type+fn]( window.event );}保证正确的this指向。
addClass注意看是利用正则防止加入重复的classname,比如classname="tb js",这种写法是同时应用了两个class,如果利用addClass在加入js时,程序自动判断不再更新classname。
cancelClick,主要是把IE的returnValue设为false,把Dom的preventDefault设为false,防止a tag的href转向再起作用,我们这里只是需要其执行脚本

slideshow-css.js


给出了一些全局的配置。

slideshow.js


加入了一个circle定时,没有点击时,每两秒切换下一幅,同时新增的数字指示切换到相应的序号,这个也是通过给a tag附加不同的css来完成的。

 

slideshow.css

slide.html


效果图

源代码下载