JavaScript轮播图
需求:
- 鼠标移动到下标页码时,也转换到相对应的图片;
- 多张图片可以自动轮播;
- 鼠标移动至图片时,停止自动轮播;
- 可以手动左右调节;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>原生JS轮播图</title>
<style>
*{
margin: 0;
padding: 0;
}
.outer{
position: relative;
top: 20px;
cursor: pointer;
}
.outer .img-box .img-item {
display: none;
position: absolute;
top: 0;
left: 50%;
transform: translateX(-50%);
}
.active{
display: block !important;
}
.outer ul{
position: absolute;
top: 250px;
left: 50%;
transform: translateX(-50%);
text-align: center;
}
.outer ul li.page-number{
list-style-type: none;
display: inline-block;
color: black;
margin: 0 6px;
font-size: 12px;
width: 20px;
height: 20px;
background-color: #05dfff;
line-height: 20px;
text-align: center;
border-radius: 50%;
}
.page-active{
background-color: #0000FF !important;
}
.outer .mover{
position: absolute;
top: 110px;
left: 50%;
height: 60px;
width: 40px;
background-color: rgba(255,255,255,0.65);
line-height: 60px;
text-align: center;
font-size: 26px;
display: none;
user-select: none; /*用户点击时,内容不能被选中*/
}
.outer .leftMover{
margin-left: -260px;
}
.outer .rightMover{
margin-left: 220px;
}
</style>
</head>
<body>
<div id="outer" class="outer">
<div class="img-box">
<img src="../img/1.jpg" class="img-item active">
<img src="../img/2.jpg" class="img-item">
<img src="../img/3.jpg" class="img-item">
<img src="../img/4.jpg" class="img-item">
</div>
<ul>
<li class="page-number page-active">1</li>
<li class="page-number">2</li>
<li class="page-number">3</li>
<li class="page-number">4</li>
</ul>
<a id="leftMover" class="mover leftMover"><</a>
<a id="rightMover" class="mover rightMover">></a>
</div>
<script>
var objectImgItems = document.getElementsByClassName("img-item");
var objectRowItems = document.getElementsByClassName("page-number");
var objectOuter = document.getElementById("outer");
var objectMover = document.getElementsByClassName("mover");
var objectLeftMover = document.getElementById("leftMover");
var objectRightMover = document.getElementById("rightMover");
<!-- 获取node在nodeList中的索引值 -->
function getIndex(node, nodeList) {
for (var index=0; index<nodeList.length; index++){
if (nodeList[index] === node){
return index
}
}
}
<!-- 根据传入的页码索引值,转换图片和页码 -->
function move(numberIndex) {
for (var i=0; i<objectImgItems.length; i++){
if (i === numberIndex) {
objectImgItems[i].classList.add("active");
objectRowItems[i].classList.add("page-active");
} else {
objectImgItems[i].classList.remove("active");
objectRowItems[i].classList.remove("page-active");
}
}
}
<!-- 鼠标覆盖页码时,图片和页码进行转换 -->
for (var i=0; i<objectRowItems.length; i++){
objectRowItems[i].onmouseover = function () {
var numberIndex = getIndex(this, objectRowItems);
move(numberIndex);
pageNumber = numberIndex;
};
}
<!-- 鼠标移动到整个模块,则显示左右移动的图标,图片停止自动转换 -->
objectOuter.onmouseover = function () {
clearInterval(intervalId);
for (var i=0; i<objectMover.length; i++){
objectMover[i].classList.add("active");
}
};
<!-- 鼠标离开整个模块,则隐藏左右移动的图标,图片开始自动转换 -->
objectOuter.onmouseout = function () {
intervalId = setInterval(directionMove, 2000);
for (var i=0; i<objectMover.length; i++){
objectMover[i].classList.remove("active");
}
};
<!-- 添加页码变量,通过自增、自减,实现左右转换 -->
var pageNumber = 0;
function directionMove(isLeft) {
if (isLeft){
if (pageNumber === 0) {
pageNumber = 4;
}
pageNumber--;
} else {
if (pageNumber === 3) {
pageNumber = -1;
}
pageNumber++;
}
move(pageNumber);
}
<!-- 添加定时器,实现自动转换 -->
var intervalId = setInterval(directionMove, 2000);
<!-- 右转换 -->
objectRightMover.onclick = function () {
directionMove();
};
<!-- 左转换 -->
objectLeftMover.onclick = function () {
directionMove(true);
}
</script>
</body>
</html>
JavaScript轮播图的更多相关文章
- JavaScript 轮播图
这是我自己做的一个轮播图,大家可以看看 ,我还没进行优化.有改进的地方可以私聊 布局什么的你们自己搞定吧 <div class="slider" id="circl ...
- 练习:javascript轮播图效果
javascript轮播自动播放切换滑过停止,上一页/下一页 <!DOCTYPE html> <html lang="en"> <head> & ...
- 超详细的原生JavaScript轮播图(幻灯片)的制作
本次轮播图的制作主要分为3个部分,分别是:设置定时器自动轮播:点击左右切换按钮轮播:下方点击按钮轮播.具体实现步骤如下: (效果图) html部分代码如下: <div class="s ...
- JavaScript 轮播图实例
HTML代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <t ...
- JavaScript 自适应轮播图
代码 话不多说,先上代码,方便复制粘贴.演示 <!DOCTYPE html> <html lang="en"> <head> <meta ...
- 带轮播图、导航栏、商品的简单html,以及轮播图下边数字随轮播图的改变而改变
---恢复内容开始--- 在做这个的时候,最不会的是中间轮播图下边的数字是如何实现转变的,后来加入了jQuery就能实现了. css部分: <style type="text/css& ...
- 自己用原生JS写的轮播图,支持移动端触摸滑动,分页器圆点可以支持mouseover鼠标移入和click点击,高手看了勿喷哈
自己用原生JavaScript写的轮播图,分页器圆点按钮可支持click点击,也可支持mouseover鼠标悬浮触发,同时支持移动端触摸滑动,有兴趣的友友可以试试哈,菜鸟一枚,高手看了勿喷,请多多指正 ...
- jquery 广告轮播图
轮播图 /*轮播图基本功能: * 1图片切换 * 1.1图片在中间显示 * 1.2图片淡入淡出 * 2左右各有一个按钮 * 2.1点击左按钮,图片切换上一张 * 2.2点击右按钮,图片切换下一张 * ...
- 【JavaScript】固定布局轮播图特效
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- MyBatis学习 之 四、动态SQL语句
有些时候,sql语句where条件中,需要一些安全判断,例如按某一条件查询时如果传入的参数是空,此时查询出的结果很可能是空的,也许我们需要参数为空时,是查出全部的信息.使用Oracle的序列.mysq ...
- 【HNOI 2002】 营业额统计
[题目链接] 点击打开链接 [算法] 观察式子 : 最小波动值 = min{|该天营业额 - 之前某天的营业额|} = min{该天营业额 - 该天营业额的前驱,该天营业额的后继 - 该天营业额} 用 ...
- eclipse快捷键设置
文章斋词水电费 55 48 Eclipse中10个最有用的快捷键组合 一个Eclipse骨灰级开发者总结了他认为最有用但又不太为人所知的快捷键组合.通过这些组合可以更加容易的浏览源代码,使得整体的开 ...
- (四)SpringBoot如何定义消息转换器
一:添加fastjson依赖 <dependency> <groupId>com.alibaba</groupId> <artifactId>fastj ...
- 继续(3n+1)猜想 (25)
#include <algorithm> #include <iostream> using namespace std; int main(){ ] = { }; ], nu ...
- C. Coconut(2017 ACM-ICPC 亚洲区(乌鲁木齐赛区)网络赛)
额,只是一道签到题,emmm直接代码: #include <cstdio> #include <cstring> #include <algorithm> usin ...
- The Django Book学习笔记 04 模板
如果使用这种方法制作文章肯定不是一个好方法,尽管它便于你理解是怎么工作的. def current_datetime(request): now = datetime.datetime.now() h ...
- Qt容器类之二:迭代器
一.介绍 遍历一个容器可以使用迭代器(iterators)来完成,迭代器提供了一个统一的方法来访问容器中的项目.Qt的容器类提供了两种类型的迭代器:Java风格迭代器和STL风格迭代器.如果只是想按顺 ...
- 【bzoj2084】[Poi2010]Antisymmetry
2084: [Poi2010]Antisymmetry Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 1205 Solved: 756[Submit ...
- java基本数据类型在栈中怎么存放的?
参考地址:https://www.zhihu.com/question/24747160 问:int a = 3; 首先它会在栈中创建一个变量为a的引用,然后查找有没有字面值为3的地址,没找到,就开辟 ...