【Vue3 组件封装】vue3 轮播图组件封装

以下是一个简化的Vue 3轮播图组件的例子,包含了基本的功能和样式。




<template>
  <div class="carousel">
    <div class="carousel-inner" :style="{ 'transform': `translateX(${currentSlide}px)` }">
      <div v-for="(item, index) in items" :key="index" class="carousel-item">
        <!-- 这里放置轮播图项的内容 -->
        <img :src="item.image" alt="carousel-image">
      </div>
    </div>
    <!-- 这里放置指示点 -->
    <div class="carousel-dots">
      <span v-for="(dot, index) in items" :key="index" :class="{ 'active': index === currentSlide }" @click="goToSlide(index)"></span>
    </div>
  </div>
</template>
 
<script>
export default {
  name: 'Carousel',
  props: {
    items: {
      type: Array,
      default: () => []
    }
  },
  data() {
    return {
      currentSlide: 0,
      interval: null
    };
  },
  mounted() {
    this.startAutoPlay();
  },
  beforeUnmount() {
    this.stopAutoPlay();
  },
  methods: {
    goToSlide(index) {
      this.currentSlide = -(index * 100); // 假设每个项占100px宽
    },
    startAutoPlay() {
      if (this.interval) return;
      this.interval = setInterval(() => {
        this.goToNextSlide();
      }, 3000); // 自动播放间隔
    },
    stopAutoPlay() {
      if (this.interval) {
        clearInterval(this.interval);
        this.interval = null;
      }
    },
    goToNextSlide() {
      this.currentSlide -= 100; // 假设每个项占100px宽
      if (this.currentSlide < -(this.items.length * 100)) {
        this.currentSlide = 0;
      }
    }
  }
};
</script>
 
<style scoped>
.carousel {
  position: relative;
  overflow: hidden;
  max-width: 600px;
}
.carousel-inner {
  display: flex;
  transition: transform 0.5s ease;
}
.carousel-item {
  width: 100%;
}
.carousel-item img {
  width: 100%;
  display: block;
}
.carousel-dots {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
}
.carousel-dots span {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin: 0 5px;
  cursor: pointer;
  background-color: #ccc;
}
.carousel-dots .active {
  background-color: #333;
}
</style>

这个组件提供了基本的轮播图功能,包括自动播放、点击指示点切换等。样式和动画是简化的,仅用于演示。在实际应用中,你需要根据自己的设计进行样式调整。

VUE
最后修改于:2024年08月19日 08:03

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日