本文实例讲述了原生JS实现的自动轮播图功能。分享给大家供大家参考,具体如下:
轮播图的用处
轮播图是现在网站网页上最常见的效果之一,很多网站上都会用到,淘宝京东等等。有些自动选项卡也是需要用到的,而且它的可重复性高。在这里分享一下,用js原生代码,实现轮播图的常见效果!
轮播图的原理
一系列的大小相等的图片平铺,利用CSS布局只显示一张图片,其余隐藏。通过定时器实现自动播放。
Html布局
首先父容器banner存放所有内容,子容器img-list存放图片。子容器list存放按钮小圆点。圆点我使用了背景图片的方式!
<div id="banner">
<ul id="img-list">
<li><img src="/UploadFiles/2021-04-02/banner1.png">
css修饰
1、对盒子模型,文档流的理解,绝对定位问题。
2、图片有固定的的宽高,先在img-list中设置三张图片总共的宽,多余的将overflow: hidden;进行隐藏!载将其图片下的li设置往右浮动。
3、将list span中的宽高固定,给个背景图片。第一张图片上设个默认的黄色圆点图片。
#banner {
width:100%;
padding:0;
clear: both;
position: relative;
height: 400px;
z-index:1;
}
#img-list {
display: block;
width:5760px;
height: 400px;
overflow: hidden;
z-index:1;
position: relative;
}
#img-list li{
float: left;
width:100%;
height: 400px;
overflow: hidden;
/* position: absolute;
top:0;
left:0; */
z-index: 2;
}
#list {
width:100%;
height:18px;
text-align: center;
position: absolute;
bottom: 10px;
z-index: 100;
}
#list > span {
width:18px;
height: 18px;
overflow: hidden;
display: inline-block;
margin:0 2px;
background: url(../images/yuan.png);
cursor: pointer;
}
#list .on {
background: url(../images/huanyu.png);
}
JS效果
1、首先我们先设置自动播放的函数
2、然后鼠标滑过容器时停止播放,鼠标离开整个容器时继续播放至下一张。
3、再定义并调用自动播放函数
var banner=document.getElementById('banner');
var imglist=document.getElementById('img-list').getElementsByTagName("li");
var list=document.getElementById('list').getElementsByTagName('span');
var index=0;
var timer=null;
//设置自动播放函数
function autoPlay () {
if (++index >= imglist.length) {index = 0};
changeImg(index);
}
// 鼠标划过整个容器时停止自动播放
banner.onmouseover = function () {
clearInterval(timer);
}
// 鼠标离开整个容器时继续播放至下一张
banner.onmouseout=function(){
timer=setInterval(autoPlay,2000);
}
// 定义并调用自动播放函数
timer = setInterval(autoPlay, 2000);
接着定义图片的切换函数
// 定义图片切换函数
function changeImg (curIndex) {
for (var i = 0; i < imglist.length; i++) {
imglist[i].style.display = "none";
list[i].className = "";
}
imglist[curIndex].style.display = "block";
list[curIndex].className = "on";
}
最后遍历所有数字导航实现划过切换至对应的图片,需获得它的索引值
for (var i = 0; i < list.length; i++) {
list[i].index=i;
list[i].onmouseover = function () {
clearInterval(timer);
changeImg(this.index);
};
到此为止,我们的轮播所有代码完成!
还不算完美,继续努力!
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript图片操作技巧大全》、《JavaScript切换特效与技巧总结》、《JavaScript运动效果与技巧汇总》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
原生JS,自动轮播图
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]
