文章地址 https://www.cnblogs.com/sandraryan/

原生js实现轮播图。

打开页面图片自动轮播,点击prev next按钮切换到上/下一张图片,点击1-5切换到对应图片。

大概长这样 不用加图片,div就可以实现

css代码:

.wrap {
/* 展示区域样式 */
width: 500px;height: 400px;
box-shadow: 0 0 10px rgba(0,0,0,.5);
display: flex;
overflow: hidden;
position: relative;
}
.swipe {
width: 2500px;
display: flex;
position: absolute;
left:;
/* 给图片变化添加过渡效果,时间不能超过定时器一次的时间,否则会冲突 */
transition: .8s;
}
/* 被轮播的子元素样式 */
.box{
width: 500px;height: 400px;
background-color: rgb(228, 226, 226);
color: #fff;
font-size: 200px;
}
button{
width: 100px;height: 40px;
margin: 10px 5px;
border-radius: 8px;
background-color: rgb(202, 202, 202);
font-size: 22px;
color: white;
}

页面结构:

<!-- 一些按钮 -->
<button class="prev">prev</button>
<button class="next">next</button>
<br>
<button class="btn">one</button>
<button class="btn">two</button>
<button class="btn">three</button>
<button class="btn">four</button>
<button class="btn">five</button>
<!-- 展示区域 -->
<div class="wrap">
<!-- 被轮播的元素父级 -->
<div class="swipe">
<!-- 被轮播的子元素列表 -->
<div class="box">box1</div>
<div class="box">box2</div>
<div class="box">box3</div>
<div class="box">box4</div>
<div class="box">box5</div>
</div>
</div>

js代码:

 <script>
// 获取元素
var prev = document.querySelector(".prev");
var next = document.querySelector(".next");
var btns = document.querySelectorAll(".btn");
var swipe = document.querySelector(".swipe"); // 自动播放
// 封装函数
// 判断索引,改变left值的函数
function nextFn(){
index = index == 4 ? 0 : ++index;
// 定位元素left才会生效
swipe.style.left = -index * 500 + "px";
} // 定时器的函数
function autoPlay(){
autoTinmer = setInterval(function(){
// left初始值为0,每张图片的left是图片宽度乘图片数量
// 只有五张图片,能移动的left最大的left是四张图的,index等于4的时候恢复到0,否则index++
nextFn();
},2000);
}
// 页面一刷新就自动播放;
autoPlay();
// 声明当前展示的图片的顺序
var index = -1;
var autoTinmer; // 点击prev next
next.onclick = function(){
// 先停止自动播放 先展示完下一张
clearInterval(autoTinmer);
// 点击next立即展示下一张
nextFn();
//继续自动播放
autoPlay();
}
prev.onclick = function(){
clearInterval(autoTinmer);
// 点击prev立即展示上一张
index = index == 0 ? 4 : --index;
swipe.style.left = -index * 500 + "px";
autoPlay();
}
// 点击对应顺序按钮
// 循环遍历所有1-5的button
for(var j = 0; j < btns.length; j++){
// 每一个btn绑定点击事件
btns[j].onclick = function(){
// 先停止自动播放的定时器
clearInterval(autoTinmer);
// 获取当前按钮在btns中的顺序获取到
// 这里不能用indexOf方法,因为这是一个伪数组,不是一个数组,不能使用数组的方法
// getAttribute获取为标签自定义html属性的值
var i = this.getAttribute("data-i");
// console.log(i);
// 根据这个顺序设置swipe的left值
swipe.style.left = - i * 500 + "px";
// 恢复自动播放的定时器
autoPlay();
}
}
</script>

the end (●ˇ∀ˇ●)

原生js用div实现简单的轮播图的更多相关文章

  1. 告别组件之教你使用原生js和css写移动端轮播图

    在工作中由于项目需要要写一个轮播图,本想使用组件直接调用实现快速开发,但是一想到自己经常使用组件但是让自己手写的话确实一点都不会. 一个不会手写组件的前端程序员不是一个好程序员!于是打算自己手写一个. ...

  2. 原生js实现一个简单的轮播图

    想锻炼一下自己的原生js能力可以从写一个轮播图开始,轮播图的运用想必大家都知道吧,好了废话不多说,开始记笔记了,一些需要注意的点,我都在代码中标注了 首先是构造html: <div id=&qu ...

  3. vue.js学习之better-scroll封装的轮播图初始化失败

    vue.js学习之better-scroll封装的轮播图初始化失败 问题一:slider组件初始化失败 原因:页面异步获取数据很慢,导致slider初始化之后,数据还未获取到,导致图片还未加载 解决方 ...

  4. js原生选项卡(自动播放无缝滚动轮播图)二

    今天分享一下自动播放轮播图,自动播放轮播图是在昨天分享的轮播图的基础上添加了定时器,用定时器控制图片的自动切换,函数中首先封装一个方向的自动播放工能的小函数,这个函数中添加定时器,定时器中可以放向右走 ...

  5. 原生JavaScript(js)手把手教你写轮播图插件(banner)

    ---恢复内容开始--- 1.轮播图插件 1.什么是插件: 为已有的程序增加功能 2.插件的特点(为什么要做成一个插件)与注意事项: 1.通用性,可移植性强 2.兼容性:不会对其他代码产生影响 3.创 ...

  6. JS框架_(Bootstrap.js)实现简单的轮播图

    Bootstrap框架中 轮播(Carousel)插件是一种灵活的响应式的向站点添加滑块的方式 轮播图效果: <!DOCTYPE html> <html> <head&g ...

  7. Js封装的动画函数实现轮播图

    ---恢复内容开始--- 效果图说明:当鼠标移到哪一个按钮上的时候会自动跳转到某一张图片上,并且按钮会以高亮显示 项目目录结构 用到的js封装的animate()动画         function ...

  8. <day006>bootstrap的简单学习 + 轮播图

    任务1:bootstrap的简单学习 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta c ...

  9. 最最最简单的轮播图(JQuery)

    html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

随机推荐

  1. 将jacoco集成到测试工具平台

    最近在做接口测试,想通过代码覆盖率来判断一下接口用例是否缺失,但是每次通过命令来生成覆盖率报告,感觉太麻烦,所以就想着把jacoco集成到测试工具平台中,只需要点几个按钮,就能查看到覆盖率报告. 测试 ...

  2. javascript函数式编程和链式优化

    1.函数式编程理解 函数式编程可以理解为,以函数作为主要载体的编程方式,用函数去拆解.抽象一般的表达式 与命令式相比,这样做的好处在哪?主要有以下几点: (1)语义更加清晰 (2)可复用性更高 (3) ...

  3. Hdu 4923(单调栈)

    题目链接 Room and Moor Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Ot ...

  4. Day2-转自金角大王

    本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...

  5. Codeforces 293B Distinct Paths DFS+剪枝+状压

    目录 题面 题目链接 题意翻译 输入输出样例 输入样例#1 输出样例#1 输入样例#2 输出样例#2 输入样例#3 输出样例#3 输入样例#4 输出样例#4 说明 思路 AC代码 总结 题面 题目链接 ...

  6. 洛谷 P1073 最优贸易 最短路+SPFA算法

    目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例 输出样例 说明 思路 AC代码 题面 题目链接 P1073 最优贸易 题目描述 C国有 $ n $ 个大城市和 ...

  7. MaxCompute 助力衣二三构建智能化运营工具

    摘要:本文由衣二三CTO程异丁为大家讲解了如何基于MaxCompute构建智能化运营工具.衣二三作为亚洲最大的共享时装平台,MaxCompute是如何帮助它解决数据提取速度慢.数据口径差异等问题呢?程 ...

  8. 微信小程序 —— wepy 使用 Vant Weapp

    一.下载 npm i @vant/weapp -S --production 下载完毕之后,就可以在 node_modules 文件夹里,看见下载的包了. 2.移动文件夹 把刚刚下载的包文件夹下的 l ...

  9. linux下播放器设计和开发

    http://blog.csdn.net/henryjee/article/details/6737392 本文根据DawnLightPlayer的开发经验写成.DawnLithtPlayer是今天3 ...

  10. 值得研究的J2EE开源项目推荐

    导读:笔者在学习J2EE的过程中发现了一些很有用,而且很值得学习的开源项目,在此推荐给大家. 关键词:J2EE 开源项目 J2SE JBoss SOA EJB   这篇文章写在我研究J2SE.J2EE ...