代码改变世界

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

  BAsil  阅读(3341)  评论(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


效果图

源代码下载

编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
历史上的今天:
2006-07-04 使用DAAB3.1连接多种数据库(SqlServer,OleDB,ODBC)(原创)
点击右上角即可分享
微信分享提示