基于JavaScript实现带缩略图的轮播效果


Posted in Javascript onJanuary 12, 2017

先瞄一眼js轮播效果图

基于JavaScript实现带缩略图的轮播效果

代码:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style>
*{padding:0;margin:0;}
#content {width:400px;height:500px;margin:10px auto;position:relative;border:1px solid #000;color:red;font-size:20px;}
#title, #bottom{position:absolute;width:400px;height:30px;line-height:30px;text-align:center;font-size:20px;background:#f1f1f1;}
#bottom{bottom:0;cursor:pointer;}
#bottom span{display:inline-block;width:15px;height:15px;border-radius:15px;background:#000;text-align:center;line-height:15px;position:relative;}
#bottom span.active{background: #FFFF33;}
#bottom span div {position:absolute;width:110px;height:110px;top:-125px;left:-46px;display:none;}
#bottom span div:after{content:'';position:absolute;left:49px;bottom:-12px;border-top:7px solid #fff;border-right:5px solid transparent;border-bottom:5px solid transparent;border-left:5px solid transparent;}
#bottom span img {width:100px;height:100px;border:5px solid #fff;}
#left, #right{position:absolute;width:60px;height:60px;border-radius:60px;line-height:60px;font-size:60px;background:#FFFF66;font-weight:bold;text-align:center;top:50%;margin-top:-25px;color:#fff;cursor:pointer;filter(opacity:70);opacity:0.7;}
#left:hover,#right:hover{filter(opacity:100);opacity:1;}
#left{left:0px;}
#right{right:0px;} 
#img{width:400px;height:500px;}
</style>
<script>
window.onload = function () {
 var bottom = $('bottom'),title = $('title'),
 img = $('img'),left = $('left'),right = $('right');
 var aSpan = bottom.getElementsByTagName('span');
 var aDiv = bottom.getElementsByTagName('div');
 var arr = ['图片一','图片二','图片三', '图片四'];
 var num = 0;
 // 初始化
 picTab();

 // 点击下一张
 right.onclick = function () {
 if (num === aDiv.length - 1) num = -1;
 num++;
 picTab();
 }

 // 点击上一张
 left.onclick = function () {
 if (num === 0) num = aDiv.length;
 num--;
 picTab();
 }

 function picTab() {
 title.innerHTML = arr[num];
 img.src = 'img/' + (num + 1) + '.png';
 for ( var i = 0; i < aSpan.length; i++ ) {
  aSpan[i].className = '';
 }
 aSpan[num].className = 'active';
 }
 // 鼠标移入移出显示缩略图
 for ( var i = 0; i < aSpan.length; i++ ) {
 aSpan[i].index = i;
 aSpan[i].onmouseover = function () {
  aDiv[this.index].style.display = 'block';
 }
 aSpan[i].onmouseout = function () {
  aDiv[this.index].style.display = 'none';
 }
 aSpan[i].onclick = function () {
  num = this.index;
  picTab();
 }
 }
 function $(id) { return document.getElementById(id);}
}
</script>
</head>
<body>
<div id="content">
 <div id="title">带缩略图的轮播</div>
 <div id="left"><</div>
 <div id="right">></div>
 <div id="bottom">
 <span><div><img src="img/1.png"/></div></span>
 <span><div><img src="img/2.png"/></div></span>
 <span><div><img src="img/3.png"/></div></span>
 <span><div><img src="img/4.png"/></div></span>
 </div>
 <img src="" id="img"/>
</div>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery 倒计时效果实现秒杀思路
Sep 11 Javascript
判断一个变量是数组Array类型的方法
Sep 16 Javascript
jquery取消选择select下拉框示例代码
Feb 22 Javascript
原生js模拟淘宝购物车项目实战
Nov 18 Javascript
JavaScript记录光标在编辑器中位置的实现方法
Apr 22 Javascript
jQuery弹出下拉列表插件(实现kindeditor的@功能)
Aug 16 Javascript
JavaScript解析JSON数据示例
Jul 16 Javascript
Node4-5静态资源服务器实战以及优化压缩文件实例内容
Aug 29 Javascript
React-redux实现小案例(todolist)的过程
Sep 29 Javascript
浅谈TypeScript 用 Webpack/ts-node 运行的配置记录
Oct 11 Javascript
Element Dropdown下拉菜单的使用方法
Jul 26 Javascript
Vue中避免滥用this去读取data中数据
Mar 02 Vue.js
js通过指定下标或指定元素进行删除数组的实例
Jan 12 #Javascript
js仿搜狐视频记录片列表展示效果
May 30 #Javascript
原生js实现商品放大镜效果
Jan 12 #Javascript
JS 在数组指定位置插入/删除数据的方法
Jan 12 #Javascript
JS图片压缩(pc端和移动端都适用)
Jan 12 #Javascript
原生js实现淘宝购物车功能
Jun 23 #Javascript
jQuery实现拖拽可编辑模块功能代码
Jan 12 #Javascript
You might like
19个Android常用工具类汇总
2014/12/30 PHP
网站防止被刷票的一些思路与方法
2015/01/08 PHP
PHP实现自动识别Restful API的返回内容类型
2015/02/07 PHP
ThinkPHP3.2.2的插件控制器功能
2015/03/05 PHP
thinkphp配置文件路径的实现方法
2016/08/30 PHP
php多线程并发实现方法
2016/09/30 PHP
PHP中常用的魔术方法
2017/04/28 PHP
PHP不使用内置函数实现字符串转整型的方法示例
2017/07/03 PHP
PHP实现APP微信支付的实例讲解
2018/02/10 PHP
PHP实现获取文件mime类型多种方法解析
2020/05/28 PHP
jQuery温习篇 强大的JQuery选择器
2010/04/24 Javascript
高性能WEB开发 flush让页面分块,逐步呈现 flush让页面分块,逐步呈现
2010/06/19 Javascript
JS中的构造函数详细解析
2014/03/10 Javascript
分享一个自己写的简单的javascript分页组件
2015/02/15 Javascript
基于JS实现PHP的sprintf函数实例
2015/11/14 Javascript
RequireJS 依赖关系的实例(推荐)
2017/01/21 Javascript
jQuery实现复制到粘贴板功能
2017/02/11 Javascript
selenium 与 chrome 进行qq登录并发邮件操作实例详解
2017/04/06 Javascript
JS解析url查询参数的简单代码
2017/08/06 Javascript
使用JavaScript实现一个小程序之99乘法表
2017/09/21 Javascript
jQuery实现的移动端图片缩放功能组件示例
2020/05/01 jQuery
[01:45]典藏宝瓶2+祈求者身心——这就是DOTA2TI9总奖金突破3000万美元的秘密
2019/07/21 DOTA
python字符串替换示例
2014/04/24 Python
Python探索之实现一个简单的HTTP服务器
2017/10/28 Python
python实现朴素贝叶斯分类器
2018/03/28 Python
在python中对变量判断是否为None的三种方法总结
2019/01/23 Python
Python pandas DataFrame操作的实现代码
2019/06/21 Python
Python中 CSV格式清洗与转换的实例代码
2019/08/29 Python
python实现WebSocket服务端过程解析
2019/10/18 Python
突袭HTML5之Javascript API扩展4—拖拽(Drag/Drop)概述
2013/01/31 HTML / CSS
简约控的天堂:The Undone
2016/12/21 全球购物
《陈毅探母》教学反思
2014/05/01 职场文书
2014年端午节演讲稿范文
2014/05/23 职场文书
机关领导干部作风整顿整改措施
2014/09/19 职场文书
教师思想工作总结2015
2015/05/13 职场文书
2019餐饮行业创业计划书!
2019/06/27 职场文书