JS实现横向轮播图(初级版)


Posted in Javascript onJune 24, 2020

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

描述:

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

效果:

JS实现横向轮播图(初级版)

代码:

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;
 }
 ul{
 position: absolute;
 bottom: 20px;
 list-style: none;
 margin: auto;
 left: 45%;
 }
 li
 {
 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>
 <ul>
 <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>

精彩专题分享:jQuery图片轮播 JavaScript图片轮播 Bootstrap图片轮播

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

Javascript 相关文章推荐
jquery一句话全选/取消全选
Mar 01 Javascript
基于JQuery的类似新浪微博展示信息效果的代码
Jul 23 Javascript
jQuery找出网页上最高元素的方法
Mar 20 Javascript
使用jquery.qrcode.min.js实现中文转化二维码
Mar 11 Javascript
基于jQuery实现仿百度首页选项卡切换效果
May 29 Javascript
Angular2学习教程之TemplateRef和ViewContainerRef详解
May 25 Javascript
使用react-router4.0实现重定向和404功能的方法
Aug 28 Javascript
jQuery实现可兼容IE6的滚动监听功能
Sep 20 jQuery
微信小程序有旋转动画效果的音乐组件实例代码
Aug 22 Javascript
uniapp实现可以左右滑动导航栏
Oct 21 Javascript
JavaScript实现网页留言板功能
Nov 23 Javascript
vue中三级导航的菜单权限控制
Mar 31 Vue.js
JS数组方法shift()、unshift()用法实例分析
Jan 18 #Javascript
微信小程序开发中var that =this的用法详解
Jan 18 #Javascript
JavaScript实现滑动门效果
Jan 18 #Javascript
JS数组方法push()、pop()用法实例分析
Jan 18 #Javascript
vue中使用WX-JSSDK的两种方法(推荐)
Jan 18 #Javascript
JS数组方法join()用法实例分析
Jan 18 #Javascript
JavaScript进制转换实现方法解析
Jan 18 #Javascript
You might like
php5.3 废弃函数小结
2010/05/16 PHP
php5.3中连接sqlserver2000的两种方法(com与ODBC)
2012/12/29 PHP
PHP遍历文件夹与文件类及处理类用法实例
2014/09/23 PHP
PHP简单实现HTTP和HTTPS跨域共享session解决办法
2015/05/27 PHP
浅析PHP类的反射来实现依赖注入过程
2018/02/06 PHP
js DataSet数据源处理代码
2010/03/29 Javascript
jquery tab标签页的制作
2010/05/10 Javascript
javascript之bind使用介绍
2011/10/09 Javascript
在AngularJS中如何使用谷歌地图把当前位置显示出来
2016/01/25 Javascript
JavaScript跨域调用基于JSON的RESTful API
2016/07/09 Javascript
Bootstrap导航条的使用和理解3
2016/12/14 Javascript
angular select 默认值设置方法
2017/06/23 Javascript
jQuery+vue.js实现的九宫格拼图游戏完整实例【附源码下载】
2017/09/12 jQuery
bootstrap fileinput插件实现预览上传照片功能
2018/01/23 Javascript
node puppeteer(headless chrome)实现网站登录
2018/05/09 Javascript
JavaScript创建、读取和删除cookie
2019/09/03 Javascript
微信用户访问小程序的登录过程详解
2019/09/20 Javascript
你不知道的 TypeScript 高级类型(小结)
2020/08/28 Javascript
python关闭windows进程的方法
2015/04/18 Python
Python读取Json字典写入Excel表格的方法
2018/01/03 Python
Python爬虫实例_城市公交网络站点数据的爬取方法
2018/01/10 Python
Python 统计字数的思路详解
2018/05/08 Python
NumPy 基本切片和索引的具体使用方法
2019/04/24 Python
零基础使用Python读写处理Excel表格的方法
2019/05/02 Python
Pandas聚合运算和分组运算的实现示例
2019/10/17 Python
python 图片二值化处理(处理后为纯黑白的图片)
2019/11/01 Python
如何在python中实现随机选择
2019/11/02 Python
J2EE面试题集锦(附答案)
2013/08/16 面试题
优秀企业获奖感言
2014/02/01 职场文书
全国道德模范事迹
2014/02/01 职场文书
餐厅筹备计划书
2014/04/25 职场文书
焦裕禄精神心得体会
2014/09/02 职场文书
2014年党的群众路线整改措施思想汇报
2014/10/12 职场文书
个人工作年终总结
2015/03/09 职场文书
详解nginx.conf 中 root 目录设置问题
2021/04/01 Servers
带你彻底理解JavaScript中的原型对象
2021/04/14 Javascript