使用构造函数以及原型的方法实现图片轮播

时间: 2023-05-30 17:07:59 浏览: 71
以下是使用构造函数和原型的方法实现图片轮播的示例代码: ```html <!DOCTYPE html> <html> <head> <title>图片轮播</title> <style> .container { width: 500px; height: 300px; position: relative; overflow: hidden; } .container img { width: 500px; height: 300px; position: absolute; top: 0; left: 0; opacity: 0; transition: opacity 1s; } .container img.active { opacity: 1; } .controls { position: absolute; top: 50%; transform: translateY(-50%); z-index: 1; } .controls button { display: inline-block; width: 20px; height: 20px; border-radius: 50%; background-color: #fff; margin: 0 5px; cursor: pointer; border: none; outline: none; } .controls button.active { background-color: #000; } </style> </head> <body> <div class="container"></div> <div class="controls"></div> <script> function Slider(container, images) { this.container = container; this.images = images; this.currentIndex = 0; this.timer = null; this.controls = null; this.init(); } Slider.prototype = { constructor: Slider, init: function() { this.renderImages(); this.renderControls(); this.addListeners(); this.play(); }, renderImages: function() { var html = ''; for (var i = 0; i < this.images.length; i++) { html += '<img src="' + this.images[i] + '" alt="">'; } this.container.innerHTML = html; this.container.querySelector('img').classList.add('active'); }, renderControls: function() { var html = ''; for (var i = 0; i < this.images.length; i++) { html += '<button></button>'; } this.controls = this.container.nextSibling; this.controls.innerHTML = html; this.controls.querySelector('button').classList.add('active'); }, addListeners: function() { var self = this; this.controls.addEventListener('click', function(event) { if (event.target.tagName === 'BUTTON') { self.stop(); self.goTo(parseInt(event.target.innerHTML) - 1); self.play(); } }); }, goTo: function(index) { if (index === this.currentIndex) { return; } var currentImage = this.container.querySelector('img.active'); var nextImage = this.container.querySelectorAll('img')[index]; var currentButton = this.controls.querySelector('button.active'); var nextButton = this.controls.querySelectorAll('button')[index]; currentImage.classList.remove('active'); nextImage.classList.add('active'); currentButton.classList.remove('active'); nextButton.classList.add('active'); this.currentIndex = index; }, play: function() { var self = this; this.timer = setInterval(function() { var nextIndex = (self.currentIndex + 1) % self.images.length; self.goTo(nextIndex); }, 2000); }, stop: function() { clearInterval(this.timer); } }; var container = document.querySelector('.container'); var images = ['https://via.placeholder.com/500x300/ff0000', 'https://via.placeholder.com/500x300/00ff00', 'https://via.placeholder.com/500x300/0000ff']; new Slider(container, images); </script> </body> </html> ``` 这个示例代码创建了一个名为 `Slider` 的构造函数,接受两个参数:图片容器和图片数组。构造函数的原型对象定义了轮播的各种方法,包括初始化、渲染图片、渲染控制按钮、添加事件监听器、跳转到指定图片、播放和停止。在构造函数的 `init` 方法中,调用了其他的方法,按照顺序执行了初始化操作。在最后一行创建了一个 `Slider` 的实例,传入了图片容器和图片数组。 在 HTML 中,需要把图片容器和控制按钮容器分别创建出来,并放在合适的位置。图片容器需要设置 `position: relative` 和 `overflow: hidden`,使得图片能够在容器内部水平滚动。控制按钮容器需要设置 `position: absolute` 和 `top: 50%; transform: translateY(-50%)`,使得按钮能够在容器垂直居中。需要注意的是,控制按钮容器应该放在图片容器的后面,以便通过 `nextSibling` 属性获取到。 CSS 样式中定义了图片和控制按钮的样式,使得图片能够在容器内部水平滚动,且当前图片和当前控制按钮能够被高亮显示出来。 JavaScript 代码中创建了一个 `Slider` 的实例,并传入了图片容器和图片数组。在 `Slider` 的构造函数中,调用了 `init` 方法,按照顺序执行了初始化操作。在 `init` 方法中,调用了其他的方法,包括渲染图片、渲染控制按钮、添加事件监听器、播放轮播。其中,`renderImages` 和 `renderControls` 方法分别根据图片数组渲染出图片和控制按钮,并将它们添加到相应的容器中。`addListeners` 方法给控制按钮容器添加了一个 `click` 事件监听器,当用户点击控制按钮时,停止轮播、跳转到指定图片、并重新开始轮播。`goTo` 方法用来实现跳转到指定图片,它会根据当前索引和目标索引之间的差值,来决定是向左滚动还是向右滚动。`play` 和 `stop` 方法分别用来开始和停止轮播。在 `play` 方法中,使用 `setInterval` 方法实现定时器,每隔 2 秒钟将当前索引加 1 并跳转到下一张图片。在 `stop` 方法中,使用 `clearInterval` 方法来清除定时器,从而停止轮播。

相关推荐

最新推荐

recommend-type

使用Springboot注入带参数的构造函数实例

主要介绍了使用Springboot注入带参数的构造函数实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

c++ 子类构造函数初始化及父类构造初始化的使用

主要介绍了c++ 子类构造函数初始化及父类构造初始化的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

Javascript 构造函数详解

Javascript构造函数是非常强大的,它可能也是Javascript能被充分利用的特点之一。但是如果你想真正的了解Javascript,你还是应该明白构造函数是如何工作的。本文,我们将从三个方面来讲述构造函数。
recommend-type

C++拷贝构造函数(深拷贝与浅拷贝)详解

深拷贝和浅拷贝可以简单理解为:如果一个类拥有资源,当这个类的对象发生复制过程的时候,资源重新分配,这个过程就是深拷贝,反之,没有重新分配资源,就是浅拷贝
recommend-type

浅析C#静态类,静态构造函数,静态变量

主要介绍了浅析C#静态类,静态构造函数,静态变量 的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。