如何用JavaScript编写一个简单的纵向滚动长尾词轮播图?

2026-04-05 10:271阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1046个文字,预计阅读时间需要5分钟。

如何用JavaScript编写一个简单的纵向滚动长尾词轮播图?

原文示例代码分享,供大家参考。描述:实现纵向轮播图,包含按钮或底部数字控制轮播,可自动轮播(注意:使用的词将将其注释掉)。

javascript// 获取轮播图元素const carousel=document.querySelector('.carousel');

如何用JavaScript编写一个简单的纵向滚动长尾词轮播图?

// 获取按钮元素const prevButton=carousel.querySelector('.prev');const nextButton=carousel.querySelector('.next');

// 获取底部数字元素const dots=carousel.querySelectorAll('.dot');

// 获取轮播图图片元素const images=carousel.querySelectorAll('.image');

// 当前图片索引let currentIndex=0;

// 初始化轮播图function initCarousel() { // 设置第一张图片为显示状态 images[currentIndex].style.display='block'; // 显示对应的底部数字 dots[currentIndex].classList.add('active');}

// 显示指定索引的图片function showImage(index) { // 隐藏所有图片 images.forEach(image=> image.style.display='none'); // 隐藏所有底部数字 dots.forEach(dot=> dot.classList.remove('active')); // 显示指定索引的图片 images[index].style.display='block'; // 显示对应的底部数字 dots[index].classList.add('active');}

// 上一张图片prevButton.addEventListener('click', ()=> { currentIndex=(currentIndex - 1 + images.length) % images.length; showImage(currentIndex);});

// 下一张图片nextButton.addEventListener('click', ()=> { currentIndex=(currentIndex + 1) % images.length; showImage(currentIndex);});

// 自动轮播let autoPlayInterval=setInterval(()=> { currentIndex=(currentIndex + 1) % images.length; showImage(currentIndex);}, 3000);

// 鼠标悬停停止自动轮播carousel.addEventListener('mouseover', ()=> { clearInterval(autoPlayInterval);});

// 鼠标移出开始自动轮播carousel.addEventListener('mouseout', ()=> { autoPlayInterval=setInterval(()=> { currentIndex=(currentIndex + 1) % images.length; showImage(currentIndex); }, 3000);});

// 初始化轮播图initCarousel();

本文实例为大家分享了JS实现纵向轮播图的具体代码,供大家参考,具体内容如下

描述:

纵向buton或者底部数字控制轮播,可以实现自动轮播(注释了,使用的话将其注释消掉),核心知识是数据驱动图像的透明度达到效果。

效果:

代码:

js文件:

/* * 工厂模式 * */ var Method=(function () { return { loadImage:function (arr,callback) { var img=new Image(); img.arr=arr; img.list=[]; img.num=0; img.callback=callback; // 如果DOM对象下的事件侦听没有被删除掉,将会常驻堆中 // 一旦触发了这个事件需要的条件,就会继续执行事件函数 img.addEventListener("load",this.loadHandler); img.self=this; img.src=arr[img.num]; }, loadHandler:function (e) { this.list.push(this.cloneNode(false)); this.num++; if(this.num>this.arr.length-1){ this.removeEventListener("load",this.self.loadHandler); this.callback(this.list); return; } this.src=this.arr[this.num]; }, $c:function (type,parent,style) { var elem=document.createElement(type); if(parent) parent.appendChild(elem); for(var key in style){ elem.style[key]=style[key]; } return elem; } } })();

html文件:

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> #con,#bgImg,#bgImg img { width: 100%; height: 500px; } #con { position: relative; margin: auto; } #bgImg{ position: absolute; } #bgImg img{ opacity: 1; transition: all 1s; position: absolute; left:0; top:0; } #iconImg { position: absolute; width: 120px; right: 50px; top:30px; } #iconImg img { margin-top: 8px; border: 2px solid #FFA50000; transition: all 0.5s; } </style> <script src="js/Method.js"></script> </head> <body> <div id="con"> <div id="bgImg"> <img src="img/a.jpeg"> </div> <div id="iconImg"> <img src="img/icon_a.jpeg"> <img src="img/icon_b.jpeg"> <img src="img/icon_c.jpeg"> <img src="img/icon_d.jpeg"> <img src="img/icon_e.jpeg"> </div> </div> <script> var bgImg,iconImg,prevImg,imgList;//定义大图 小图的盒子(5个img) var N=0;//图像标记 var arr=["img/a.jpeg","img/b.jpeg","img/c.jpeg","img/d.jpeg","img/e.jpeg"];//图片设置为数组形式 传参 init(); function init() { Method.loadImage(arr,loadFinishHandler)//预加载 } function loadFinishHandler(list) {//预加载赋值 imgList=list; bgImg=document.getElementById("bgImg"); iconImg=document.getElementById("iconImg"); for(var i=0;i<iconImg.children.length;i++){ iconImg.children[i].num=i; iconImg.children[i].addEventListener("click",clickHandler); } changeBorder(iconImg.firstElementChild); } setInterval(autoImg,3000); function autoImg() {//自动轮播效果 N++; //全局变量 用于控制当前轮播顺序 if (N>4) N=0; changeImg(N);//大图轮播 changeBorder(iconImg.children[N]);//小图外边框轮播 设置第几个 弄懂参数代表含义 } function clickHandler(e) { e =e || window.event; changeBorder(this); N=this.num; changeImg(this.num); } function changeBorder(elem) { if(prevImg){ prevImg.style.border="2px solid #FFA50000"; } prevImg=elem; prevImg.style.border="2px solid #FFA500"; } function changeImg(index) { if(bgImg.children.length>1){ bgImg.lastElementChild.remove(); } bgImg.lastElementChild.style.opacity="0"; imgList[index].style.opacity="1"; bgImg.insertBefore(imgList[index],bgImg.firstElementChild); } </script> </body> </html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计1046个文字,预计阅读时间需要5分钟。

如何用JavaScript编写一个简单的纵向滚动长尾词轮播图?

原文示例代码分享,供大家参考。描述:实现纵向轮播图,包含按钮或底部数字控制轮播,可自动轮播(注意:使用的词将将其注释掉)。

javascript// 获取轮播图元素const carousel=document.querySelector('.carousel');

如何用JavaScript编写一个简单的纵向滚动长尾词轮播图?

// 获取按钮元素const prevButton=carousel.querySelector('.prev');const nextButton=carousel.querySelector('.next');

// 获取底部数字元素const dots=carousel.querySelectorAll('.dot');

// 获取轮播图图片元素const images=carousel.querySelectorAll('.image');

// 当前图片索引let currentIndex=0;

// 初始化轮播图function initCarousel() { // 设置第一张图片为显示状态 images[currentIndex].style.display='block'; // 显示对应的底部数字 dots[currentIndex].classList.add('active');}

// 显示指定索引的图片function showImage(index) { // 隐藏所有图片 images.forEach(image=> image.style.display='none'); // 隐藏所有底部数字 dots.forEach(dot=> dot.classList.remove('active')); // 显示指定索引的图片 images[index].style.display='block'; // 显示对应的底部数字 dots[index].classList.add('active');}

// 上一张图片prevButton.addEventListener('click', ()=> { currentIndex=(currentIndex - 1 + images.length) % images.length; showImage(currentIndex);});

// 下一张图片nextButton.addEventListener('click', ()=> { currentIndex=(currentIndex + 1) % images.length; showImage(currentIndex);});

// 自动轮播let autoPlayInterval=setInterval(()=> { currentIndex=(currentIndex + 1) % images.length; showImage(currentIndex);}, 3000);

// 鼠标悬停停止自动轮播carousel.addEventListener('mouseover', ()=> { clearInterval(autoPlayInterval);});

// 鼠标移出开始自动轮播carousel.addEventListener('mouseout', ()=> { autoPlayInterval=setInterval(()=> { currentIndex=(currentIndex + 1) % images.length; showImage(currentIndex); }, 3000);});

// 初始化轮播图initCarousel();

本文实例为大家分享了JS实现纵向轮播图的具体代码,供大家参考,具体内容如下

描述:

纵向buton或者底部数字控制轮播,可以实现自动轮播(注释了,使用的话将其注释消掉),核心知识是数据驱动图像的透明度达到效果。

效果:

代码:

js文件:

/* * 工厂模式 * */ var Method=(function () { return { loadImage:function (arr,callback) { var img=new Image(); img.arr=arr; img.list=[]; img.num=0; img.callback=callback; // 如果DOM对象下的事件侦听没有被删除掉,将会常驻堆中 // 一旦触发了这个事件需要的条件,就会继续执行事件函数 img.addEventListener("load",this.loadHandler); img.self=this; img.src=arr[img.num]; }, loadHandler:function (e) { this.list.push(this.cloneNode(false)); this.num++; if(this.num>this.arr.length-1){ this.removeEventListener("load",this.self.loadHandler); this.callback(this.list); return; } this.src=this.arr[this.num]; }, $c:function (type,parent,style) { var elem=document.createElement(type); if(parent) parent.appendChild(elem); for(var key in style){ elem.style[key]=style[key]; } return elem; } } })();

html文件:

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> #con,#bgImg,#bgImg img { width: 100%; height: 500px; } #con { position: relative; margin: auto; } #bgImg{ position: absolute; } #bgImg img{ opacity: 1; transition: all 1s; position: absolute; left:0; top:0; } #iconImg { position: absolute; width: 120px; right: 50px; top:30px; } #iconImg img { margin-top: 8px; border: 2px solid #FFA50000; transition: all 0.5s; } </style> <script src="js/Method.js"></script> </head> <body> <div id="con"> <div id="bgImg"> <img src="img/a.jpeg"> </div> <div id="iconImg"> <img src="img/icon_a.jpeg"> <img src="img/icon_b.jpeg"> <img src="img/icon_c.jpeg"> <img src="img/icon_d.jpeg"> <img src="img/icon_e.jpeg"> </div> </div> <script> var bgImg,iconImg,prevImg,imgList;//定义大图 小图的盒子(5个img) var N=0;//图像标记 var arr=["img/a.jpeg","img/b.jpeg","img/c.jpeg","img/d.jpeg","img/e.jpeg"];//图片设置为数组形式 传参 init(); function init() { Method.loadImage(arr,loadFinishHandler)//预加载 } function loadFinishHandler(list) {//预加载赋值 imgList=list; bgImg=document.getElementById("bgImg"); iconImg=document.getElementById("iconImg"); for(var i=0;i<iconImg.children.length;i++){ iconImg.children[i].num=i; iconImg.children[i].addEventListener("click",clickHandler); } changeBorder(iconImg.firstElementChild); } setInterval(autoImg,3000); function autoImg() {//自动轮播效果 N++; //全局变量 用于控制当前轮播顺序 if (N>4) N=0; changeImg(N);//大图轮播 changeBorder(iconImg.children[N]);//小图外边框轮播 设置第几个 弄懂参数代表含义 } function clickHandler(e) { e =e || window.event; changeBorder(this); N=this.num; changeImg(this.num); } function changeBorder(elem) { if(prevImg){ prevImg.style.border="2px solid #FFA50000"; } prevImg=elem; prevImg.style.border="2px solid #FFA500"; } function changeImg(index) { if(bgImg.children.length>1){ bgImg.lastElementChild.remove(); } bgImg.lastElementChild.style.opacity="0"; imgList[index].style.opacity="1"; bgImg.insertBefore(imgList[index],bgImg.firstElementChild); } </script> </body> </html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。