全国咨询热线:18720358503

潍坊百度微信小程序_JS完成横向轮播图(初级版

类别:行业新闻 发布时间:2021-01-06 浏览人次:

JS实现横向轮播图(初级版)       这篇文章主要为大家详细介绍了JS实现横向轮播图的初级版,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了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 
 margin: 0;
 padding: 0;
 #carousel,#imgCon img{
 width: 1200px;
 height: 400px;
 #carousel
 position: relative;
 margin: auto;
 overflow: hidden;
 #imgCon{
 width: 6000px;
 height: 400px;
 position: absolute;
 left: 0;
 font-size: 0;
 transition: all 1s;
 #leftBn,#rightBn
 position: absolute;
 top:170px;
 #leftBn{
 left: 20px;
 #rightBn
 right: 20px;
 position: absolute;
 bottom: 20px;
 list-style: none;
 margin: auto;
 left: 45%;
 width: 20px;
 height: 20px;
 border: 1px solid red;
 border-radius: 10px;
 float: left;
 text-align: center;
 color: white;
 cursor: default;
 line-height:20px;
 font-size: 12px;
 margin-left: 8px;
 /style 
 /head 
 body 
 div id="carousel" 
 div id="imgCon" 
 img src="img/a.jpeg" 
 img src="img/b.jpeg" 
 img src="img/c.jpeg" 
 img src="img/d.jpeg" 
 img src="img/e.jpeg" 
 /div 
 li 1 /li 
 li 2 /li 
 li 3 /li 
 li 4 /li 
 li 5 /li 
 /ul 
 img src="img/left.png" id="leftBn" 
 img src="img/right.png" id="rightBn" 
 /div 
 script 
 * 数据驱动显示
 * */
 var imgCon,leftBn,rightBn,lis,ul,prevLi;
 var position=0;//图像的标记 第一张0 第二张1...
 init();
 function init() {
 imgCon=document.getElementById("imgCon");//图
 leftBn=document.getElementById("leftBn");//左按钮
 rightBn=document.getElementById("rightBn");//右按钮
 lis=document.getElementsByTagName("li");//下方数字右按钮
 ul=document.getElementsByTagName("ul")[0];
 leftBn.addEventListener("click",clickHandler);
 rightBn.addEventListener("click",clickHandler);
 for(var i=0;i lis.length;i++){//为每隔小Li 也就是底部数字赋值
 lis[i].num=i;
 lis[i].addEventListener("click",liClickHandler);
 changeLi();
// setInterval(autoImg,3000);可以实现自动
 function autoImg() {//自动轮播
 position++;
 if(position 4) position=0;
 changeImg();
 function clickHandler(e) {
 e= e || window.event;
 if(this===leftBn){
 position--;
 if(position 0) position=4;
 }else if(this===rightBn){
 position++;
 if(position 4) position=0;
 changeImg();
 function liClickHandler(e) {
 e= e || window.event;
 position=this.num;
 changeImg();
 function changeImg() {//图片的转换效果 唯一
 imgCon.style.left=-position*1200+"px";//一次一张图片的位移
 changeLi();
 function changeLi() {//底部数字的转换效果
 if(prevLi){
 prevLi.style.backgroundColor="rgba(255,0,0,0)";
 prevLi=lis[position];
 prevLi.style.backgroundColor="rgba(255,0,0,0.5)";
 /script 
 /body 
 /html 

精彩专题分享:

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


推荐阅读

潍坊百度微信小程序_JS完成横向轮播图(初级版

JS完成横着滚屏图(初中级版) 本文关键为大伙儿详尽详细介绍了JS完成横着滚屏图的初中级版,原文中实例编码详细介绍的十分详尽,具备一定的参照使用价值,很感兴趣的小伙...

2021-01-06
广州凡科互联网科技股份有限公司招聘销售运营

招聘人数:5职位信息1、负责全国各项销售数据的动态管理及分析,提供相应的支持方案,协助销售总监设置营销策略;2、负责全国各区域的销售绩效考核管理和激励政策,为每月全国...

2021-01-06
广州凡科互联网科技股份有限公司招聘客服经理

招聘人数:13职位信息1.负责下属客服人员日常管理,提供引导、支持与监督,并进行培训、考核; 2.制定和完善客户服务的管理制度,规范和完善岗位职责,优化客服流程; 3.负责电...

2021-01-06
广州凡科互联网科技股份有限公司招聘阿里巴巴

招聘人数:7职位信息岗位职责1、负责阿里巴巴国际站主账号后台的管理工作及优化排名,以及产品的上下架和布局;2、负责阿里巴巴国际站平台搜索排名和产品优化曝光,精通操作阿...

2021-01-06
广州凡科互联网科技股份有限公司招聘亚马逊站

招聘人数:13职位信息岗位职责:1、负责公司亚马逊产品的测评工作,确保账号安全的情况下按时按量完成测评任务;2、负责开发、联系、维护测评师,运营测评粉丝群,确保满足日常...

2021-01-06
广州凡科互联网科技股份有限公司招聘执行制片

招聘人数:29职位信息·岗位职责:·1、负责拍摄项目的方案评估(报价、拍摄布置、人员)、统筹、运营的管理工作,包括项目的供应商招标、制作、后期运营;·2、负责审核项目预算...

2021-01-06
X

400-8700-61718720358503
企业邮箱2639601583@qq.com
官方微信