编程 Vue 3 生成一个图片画廊,支持查看大图和切换图片

2024-11-19 08:32:43 +0800 CST views 773

使用 Vue 3 生成一个图片画廊,支持查看大图和切换图片

Vue 3 作为一个现代化的前端框架,通过其新的特性与 API 提供了更轻松的开发体验。在本篇博文中,我们将创建一个简单但功能强大的图片画廊,用户不仅可以查看缩略图,还可以点击查看大图,并在大图之间进行切换。我们将使用 Vue 3 的 setup 函数,使得我们的组件更加简洁和易于理解。

项目结构

首先,我们需要一个基本的项目结构。我们将创建一个名为 ImageGallery.vue 的组件,并在其中实现我们的逻辑。

目录结构

src/
├── components/
│   └── ImageGallery.vue
└── App.vue

示例代码

以下是 ImageGallery.vue 组件的完整代码:

<template>
  <div class="gallery">
    <h1>图片画廊</h1>
    
    <div class="thumbnails">
      <div
        class="thumbnail"
        v-for="(image, index) in images"
        :key="index"
        @click="openModal(index)"
      >
        <img :src="image.thumbnail" :alt="image.alt" />
      </div>
    </div>

    <Modal v-if="isModalOpen" @close="closeModal">
      <img :src="images[currentImageIndex].full" :alt="images[currentImageIndex].alt" />
      <button @click="prevImage">上一张</button>
      <button @click="nextImage">下一张</button>
    </Modal>
  </div>
</template>

<script setup>
import { ref } from 'vue';
import Modal from './Modal.vue';

const images = [
  {
    thumbnail: 'thumb1.jpg',
    full: 'image1.jpg',
    alt: '图片1'
  },
  {
    thumbnail: 'thumb2.jpg',
    full: 'image2.jpg',
    alt: '图片2'
  },
  {
    thumbnail: 'thumb3.jpg',
    full: 'image3.jpg',
    alt: '图片3'
  }
  // 这里可以继续添加更多图片
];

const isModalOpen = ref(false);
const currentImageIndex = ref(0);

function openModal(index) {
  currentImageIndex.value = index;
  isModalOpen.value = true;
}

function closeModal() {
  isModalOpen.value = false;
}

function prevImage() {
  currentImageIndex.value =
    (currentImageIndex.value - 1 + images.length) % images.length;
}

function nextImage() {
  currentImageIndex.value = (currentImageIndex.value + 1) % images.length;
}
</script>

<style scoped>
.gallery {
  text-align: center;
}

.thumbnails {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.thumbnail {
  margin: 10px;
  cursor: pointer;
}

.thumbnail img {
  width: 150px;
  height: 100px;
  object-fit: cover;
  border-radius: 8px;
}

button {
  margin: 10px;
}
</style>

为了实现大图查看的功能,我们需要一个 Modal 组件,用于展示大图。以下是 Modal.vue 的简单实现:

<template>
  <div class="modal-overlay" @click.self="close">
    <div class="modal-content">
      <slot></slot>
      <button @click="close">关闭</button>
    </div>
  </div>
</template>

<script setup>
import { defineEmits } from 'vue';

const emit = defineEmits(['close']);
</script>

<style scoped>
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.7);
  display: flex;
  justify-content: center;
  align-items: center;
}

.modal-content {
  background: white;
  padding: 20px;
  border-radius: 8px;
}
</style>

代码讲解

数据源

images 数组存储了每个图片的缩略图与全图的 URL 地址,增加图片只需在该数组中添加新对象。

模态框管理

使用 isModalOpen 变量来管理模态框的显示与隐藏,使用 currentImageIndex 来跟踪当前查看的图片索引。

打开模态框

openModal 方法接收索引参数,更新当前图片索引并打开模态框。

关闭模态框

closeModal 方法用于关闭模态框。

切换图片

prevImagenextImage 方法用于前后切换大图,利用模态框索引的循环逻辑实现。

小结

通过以上步骤,我们成功地用 Vue 3 创建了一个简单的图片画廊。当用户点击缩略图时,模态框会展现大图,用户可以通过按钮切换不同的图片,体验直观且流畅的浏览效果。

通过灵活运用 Vue 3 的新特性和组件化的设计理念,我们不仅能够提高开发效率,还能创建出高可维护性和可复用性的组件。

复制全文 生成海报 前端 Vue 开发 编程 图像处理

推荐文章

Python中何时应该使用异常处理
2024-11-19 01:16:28 +0800 CST
JavaScript设计模式:观察者模式
2024-11-19 05:37:50 +0800 CST
LangChain快速上手
2025-03-09 22:30:10 +0800 CST
liunx服务器监控workerman进程守护
2024-11-18 13:28:44 +0800 CST
ElasticSearch 结构
2024-11-18 10:05:24 +0800 CST
小技巧vscode去除空格方法
2024-11-17 05:00:30 +0800 CST
百度开源压测工具 dperf
2024-11-18 16:50:58 +0800 CST
IP地址获取函数
2024-11-19 00:03:29 +0800 CST
Rust开发笔记 | Rust的交互式Shell
2024-11-18 19:55:44 +0800 CST
Nginx 负载均衡
2024-11-19 10:03:14 +0800 CST
一些实用的前端开发工具网站
2024-11-18 14:30:55 +0800 CST
php curl并发代码
2024-11-18 01:45:03 +0800 CST
php常用的正则表达式
2024-11-19 03:48:35 +0800 CST
pip安装到指定目录上
2024-11-17 16:17:25 +0800 CST
Nginx rewrite 的用法
2024-11-18 22:59:02 +0800 CST
前端项目中图片的使用规范
2024-11-19 09:30:04 +0800 CST
Vue3中的事件处理方式有何变化?
2024-11-17 17:10:29 +0800 CST
程序员茄子在线接单