用html+css+js实现的一个简单的图片切换特效


Posted in Javascript onMay 28, 2014

如图所示。

用html+css+js实现的一个简单的图片切换特效
该图片切换特效实现很简单,而且兼容性很好。

html页面如下

<div class="wrapper"> 
<div id="focus"> 
<ul> 
<li><a href="http://www.lanrentuku.com/" target="_blank"><img src="img/01.jpg" alt="QQ商城焦点图效果下载" /></a></li> 
<li><a href="http://www.lanrentuku.com/" target="_blank"><img src="img/02.jpg" alt="QQ商城焦点图效果教程" /></a></li> 
<li><a href="http://www.lanrentuku.com/" target="_blank"><img src="img/03.jpg" alt="jquery商城焦点图效果" /></a></li> 
<li><a href="http://www.lanrentuku.com/" target="_blank"><img src="img/04.jpg" alt="jquery商城焦点图代码" /></a></li> 
<li><a href="http://www.lanrentuku.com/" target="_blank"><img src="img/05.jpg" alt="jquery商城焦点图源码" /></a></li> 
</ul> 
</div> </div><!-- wrapper end --> 
</body>

css样式
<style type="text/css"> 
* {margin:0; padding:0;} 
body {font-size:12px; color:#222; font-family:Verdana,Arial,Helvetica,sans-serif; background:#f0f0f0;} 
.clearfix:after {content: "."; display: block; height: 0; clear: both; visibility: hidden;} 
.clearfix {zoom:1;} 
ul,li {list-style:none;} 
img {border:0;} .wrapper {width:800px; margin:0 auto; padding-bottom:50px;} 
/* qqshop focus */ 
#focus {width:800px; height:280px; overflow:hidden; position:relative;} 
#focus ul {height:380px; position:absolute;} 
#focus ul li {float:left; width:800px; height:280px; overflow:hidden; position:relative; background:#000;} 
#focus ul li div {position:absolute; overflow:hidden;} 
#focus .btnBg {position:absolute; width:800px; height:20px; left:0; bottom:0; background:#000;} 
#focus .btn {position:absolute; width:780px; height:10px; padding:5px 10px; right:0; bottom:0; text-align:right;} 
#focus .btn span {display:inline-block; _display:inline; _zoom:1; width:25px; height:10px; _font-size:0; margin-left:5px; cursor:pointer; background:#fff;} 
#focus .btn span.on {background:#fff;} 
#focus .preNext {width:45px; height:100px; position:absolute; top:90px; background:url(img/sprite.png) no-repeat 0 0; cursor:pointer;} 
#focus .pre {left:0;} 
#focus .next {right:0; background-position:right top;} 
</style>

js脚本
$(function() { 
var sWidth = $("#focus").width(); //获取焦点图的宽度(显示面积) 
var len = $("#focus ul li").length; //获取焦点图个数 
var index = 0; 
var picTimer; //以下代码添加数字按钮和按钮后的半透明条,还有上一页、下一页两个按钮 
var btn = "<div class='btnBg'></div><div class='btn'>"; 
for(var i=0; i < len; i++) { 
btn += "<span></span>"; 
} 
btn += "</div><div class='preNext pre'></div><div class='preNext next'></div>"; 
$("#focus").append(btn); 
$("#focus .btnBg").css("opacity",0.5); 
//为小按钮添加鼠标滑入事件,以显示相应的内容 
$("#focus .btn span").css("opacity",0.4).mouseenter(function() { 
index = $("#focus .btn span").index(this); 
showPics(index); 
}).eq(0).trigger("mouseenter"); 
//上一页、下一页按钮透明度处理 
$("#focus .preNext").css("opacity",0.2).hover(function() { 
$(this).stop(true,false).animate({"opacity":"0.5"},300); 
},function() { 
$(this).stop(true,false).animate({"opacity":"0.2"},300); 
}); 
//上一页按钮 
$("#focus .pre").click(function() { 
index -= 1; 
if(index == -1) {index = len - 1;} 
showPics(index); 
}); 
//下一页按钮 
$("#focus .next").click(function() { 
index += 1; 
if(index == len) {index = 0;} 
showPics(index); 
}); 
//本例为左右滚动,即所有li元素都是在同一排向左浮动,所以这里需要计算出外围ul元素的宽度 
$("#focus ul").css("width",sWidth * (len)); 
//鼠标滑上焦点图时停止自动播放,滑出时开始自动播放 
$("#focus").hover(function() { 
clearInterval(picTimer); 
},function() { 
picTimer = setInterval(function() { 
showPics(index); 
index++; 
if(index == len) {index = 0;} 
},4000); //此4000代表自动播放的间隔,单位:毫秒 
}).trigger("mouseleave"); 
//显示图片函数,根据接收的index值显示相应的内容 
function showPics(index) { //普通切换 
var nowLeft = -index*sWidth; //根据index值计算ul元素的left值 
$("#focus ul").stop(true,false).animate({"left":nowLeft},300); //通过animate()调整ul元素滚动到计算出的position 
//$("#focus .btn span").removeClass("on").eq(index).addClass("on"); //为当前的按钮切换到选中的效果 
$("#focus .btn span").stop(true,false).animate({"opacity":"0.4"},300).eq(index).stop(true,false).animate({"opacity":"1"},300); //为当前的按钮切换到选中的效果 
} 
});

用到的左右切换图片

用html+css+js实现的一个简单的图片切换特效

Javascript 相关文章推荐
JavaScript库 开发规则
Jan 31 Javascript
jQuery插件开发全解析
Oct 10 Javascript
javascript:void(0)使用探讨
Aug 27 Javascript
浅谈javascript六种数据类型以及特殊注意点
Dec 20 Javascript
Node.js中创建和管理外部进程详解
Aug 16 Javascript
Jquery时间轴特效(三种不同类型)
Nov 02 Javascript
JS获取和修改元素样式的实例代码
Aug 06 Javascript
javascript实现获取图片大小及图片等比缩放的方法
Nov 24 Javascript
bootstrap中的 form表单属性role=&quot;form&quot;的作用详解
Jan 20 Javascript
vue2利用Bus.js如何实现非父子组件通信详解
Aug 25 Javascript
Vuex实现计数器以及列表展示效果
Mar 10 Javascript
关于JSON解析的实现过程解析
Oct 08 Javascript
HTML页面登录时的JS验证方法
May 28 #Javascript
22点关于jquery性能优化的建议
May 28 #Javascript
一个奇葩的最短的 IE 版本判断JS脚本
May 28 #Javascript
JS中使用Array函数shift和pop创建可忽略参数的例子
May 28 #Javascript
现代 JavaScript 开发编程风格Idiomatic.js指南中文版
May 28 #Javascript
node.js Web应用框架Express入门指南
May 28 #Javascript
用html5 js实现点击一个按钮达到浏览器全屏效果
May 28 #Javascript
You might like
PHP中文分词 自动获取关键词介绍
2012/11/13 PHP
LaravelS通过Swoole加速Laravel/Lumen详解
2018/03/02 PHP
Laravel推荐使用的十个辅助函数
2019/05/10 PHP
Javascript 阻止javascript事件冒泡,获取控件ID值
2009/06/27 Javascript
node.js chat程序如何实现Ajax long-polling长链接刷新模式
2012/03/13 Javascript
js string 转 int 注意的问题小结
2013/08/15 Javascript
3个可以改善用户体验的AngularJS指令介绍
2015/06/18 Javascript
JavaScript仿微博发布信息案例
2016/11/16 Javascript
jquery实现下拉框左右选择功能
2017/02/21 Javascript
详解angularjs利用ui-route异步加载组件
2017/05/21 Javascript
微信小程序switch开关选择器使用详解
2018/01/31 Javascript
JS简单实现动态添加HTML标记的方法示例
2018/04/08 Javascript
Element-ui之ElScrollBar组件滚动条的使用方法
2018/09/14 Javascript
JavaScript实现背景自动切换小案例
2019/09/27 Javascript
node.js开发辅助工具nodemon安装与配置详解
2020/02/06 Javascript
python解析xml文件实例分享
2013/12/04 Python
Python常用列表数据结构小结
2014/08/06 Python
由Python运算π的值深入Python中科学计算的实现
2015/04/17 Python
在Django中同时使用多个配置文件的方法
2015/07/22 Python
Python程序退出方式小结
2017/12/09 Python
python的格式化输出(format,%)实例详解
2018/06/01 Python
浅谈python连续赋值可能引发的错误
2018/11/10 Python
Python 文本文件内容批量抽取实例
2018/12/10 Python
python 自动批量打开网页的示例
2019/02/21 Python
python3实现微型的web服务器
2019/09/03 Python
python2 对excel表格操作完整示例
2020/02/23 Python
Python3.7在anaconda里面使用IDLE编译器的步骤详解
2020/04/29 Python
python判断all函数输出结果是否为true的方法
2020/12/03 Python
Clarks西班牙官方在线商店:clarks鞋
2019/05/03 全球购物
初三化学教学反思
2014/01/23 职场文书
学习十八大报告感言
2014/02/28 职场文书
美术指导助理求职信
2014/04/20 职场文书
敬老院献爱心活动总结
2014/07/08 职场文书
暂住证明怎么写
2015/06/19 职场文书
2016年元旦寄语
2015/08/17 职场文书
提高系统的吞吐量解决数据库重复写入问题
2022/04/23 MySQL