用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 相关文章推荐
js 事件处理函数间的Event物件是否全等
Apr 08 Javascript
jQuery实现动画效果的实例代码
May 07 Javascript
js实现支持手机滑动切换的轮播图片效果实例
Apr 29 Javascript
JS中的进制转换以及作用
Jun 26 Javascript
JS中script标签defer和async属性的区别详解
Aug 12 Javascript
浅谈JS继承_寄生式继承 &amp; 寄生组合式继承
Aug 16 Javascript
Bootstrap 源代码分析(未完待续)
Aug 17 Javascript
JavaScript函数节流的两种写法
Apr 07 Javascript
javascript数据结构中栈的应用之符号平衡问题
Apr 11 Javascript
vue实现移动端图片裁剪上传功能
Aug 18 Javascript
Node.js中的child_process模块详解
Jun 08 Javascript
详解在vue-cli3.0中自定css、js和图片的打包路径
Aug 26 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的cURL库功能简介 抓取网页、POST数据及其他
2011/04/07 PHP
PHP实现带重试功能的curl连接示例
2016/07/28 PHP
PHP中使用mpdf 导出PDF文件的实现方法
2018/10/22 PHP
javascript String 的扩展方法集合
2008/06/01 Javascript
浅谈Javascript事件处理程序的几种方式
2012/06/27 Javascript
jquery通过visible来判断标签是否显示或隐藏
2014/05/08 Javascript
用jQuery toggleClass 实现鼠标移上变色
2014/05/14 Javascript
使用forever管理nodejs应用教程
2014/06/03 NodeJs
jquery+正则实现统一的表单验证
2015/09/20 Javascript
浅谈js函数的多种定义方法与区别
2016/11/29 Javascript
详细分析JS函数去抖和节流
2017/12/05 Javascript
vue.js使用v-model指令实现的数据双向绑定功能示例
2018/05/22 Javascript
angular 组件通信的几种实现方式
2018/07/13 Javascript
vue slots 组件的组合/分发实例
2018/09/06 Javascript
React实现全局组件的Toast轻提示效果
2018/09/21 Javascript
vuex + keep-alive实现tab标签页面缓存功能
2019/10/17 Javascript
jQuery实现弹幕特效
2019/11/29 jQuery
vue+Element-ui实现分页效果
2020/11/15 Javascript
Python语言编写电脑时间自动同步小工具
2013/03/08 Python
Python实现模拟时钟代码推荐
2015/11/08 Python
numpy中矩阵合并的实例
2018/06/15 Python
Python实现的读取/更改/写入xml文件操作示例
2018/08/30 Python
Python在cmd上打印彩色文字实现过程详解
2019/08/07 Python
Python udp网络程序实现发送、接收数据功能示例
2019/12/09 Python
python爬取”顶点小说网“《纯阳剑尊》的示例代码
2020/10/16 Python
英国和爱尔兰最大的地毯零售商:Kukoon
2018/12/17 全球购物
AJAX都有哪些有点和缺点
2012/11/03 面试题
体育教育专业自荐信范文
2013/12/20 职场文书
快递业务员岗位职责
2014/01/06 职场文书
英文演讲稿
2014/05/15 职场文书
群众路线领导干部个人对照检查材料(集锦)
2014/09/23 职场文书
地陪导游欢迎词
2015/01/26 职场文书
房租涨价通知
2015/04/23 职场文书
伊索寓言读书笔记
2015/06/30 职场文书
浅谈node.js中间件有哪些类型
2021/04/29 Javascript
MySQL REVOKE实现删除用户权限
2021/06/18 MySQL