Vue3中实现轮播图

目录

[1. 轮播图介绍](#1. 轮播图介绍)

[2. 实现轮播图](#2. 实现轮播图)

[2.1 准备工作](#2.1 准备工作)

1、准备至少三张图片,并将图片文件名改为数字123

2、搭好HTML的标签

3、写好按钮和图片标签

​编辑

[2.2 单向绑定图片](#2.2 单向绑定图片)

[2.3 在按钮里使用方法](#2.3 在按钮里使用方法)

[2.4 运行代码](#2.4 运行代码)

[3. 完整代码](#3. 完整代码)


1. 轮播图介绍

首先,什么是轮播图? 轮播图是指提供【上一页】【下一页】进而能切换图片 , 这在前端页面中是十分常见的一个页面显示

那么好 , 接下来我们看看具体的效果图,这是刚运行的效果:

当我们点击下一页时,图片切换到下一张,并且点击上一页时,必须是之前的上一页

2. 实现轮播图

2.1 准备工作

因为图片的切换是由按钮控制的,所以<img src=等于后面的值一定是个变量,这样才能由按钮中的方法控制,所以我们应该把图片名称设置简单而又容易控制的

1、准备至少三张图片,并将图片文件名改为数字123

这些图片尽量与HTML文件放在同一个目录下

2、搭好HTML的标签

3、写好按钮和图片标签

这个时候,其实已经有模有样的了,我们运行一下代码:

2.2 单向绑定图片

我们要把之前的src地址改成

<img src=`${参数名}. 图片的格式**`**

同时:v-bind能绑定src 使得图片能显示到页面 , 即使id发生变化 , 也不会影响图片显示

接着在script标签中定义一个id

2.3 在按钮里使用方法

在button按钮里 , 通过@click ="方法名" 来进行事件控制图片切换

script 标签中定义方法的同时 , 对id的加减进行一个if语句判断:

2.4 运行代码

当我们在第一页时 依然点击上一页按钮, 页面就会弹窗提示

当这是最后一页的时候 , 继续下一页也会弹窗提示

3. 完整代码

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <title>轮播图</title>
</head>
<div id="app">
    <img :src=`${id}.png` style="width: 700px;height: 400px;">
    <br>
    <!-- 在button标签中添加按钮 -->
    <button @click="prevPage">上一页</button>
    <button @click="nextPage">下一页</button>
</div>

<body>
    <script type="module">
        import { createApp, ref } from "./vue.esm-browser.js"
        createApp({
            setup() {
                //定义图片id
                const id = ref(1);
                //定义方法
                //上一页
                const prevPage = () => {
                    if (id.value <= 1) {
                        alert("已经是第一张了");
                    } else {
                        id.value--;
                    }
                }
                //下一页
                const nextPage = () => {
                    if (id.value >= 3) {
                        alert("已经是最后一张了");
                    } else {
                        id.value++;
                    }
                }
                return {
                    id,
                    prevPage,
                    nextPage
                }
            }
        }).mount("#app")
    </script>
</body>

</html>
相关推荐
用户新2 小时前
V8引擎 精品漫游指南--Ignition篇(下 一) 动态执行前的事情
前端·javascript
阿里嘎多学长2 小时前
2026-04-30 GitHub 热点项目精选
开发语言·程序员·github·代码托管
叶小鸡4 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
@PHARAOH4 小时前
WHAT - GitLens vs Fork
前端
yqcoder4 小时前
前端性能优化:如何减少重绘与重排?
前端·性能优化
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
时空系4 小时前
第10篇:继承扩展——面向对象编程进阶 python中文编程
开发语言·python·ai编程
洋子4 小时前
Yank Note 系列 13 - 让 AI Agent 进入笔记工作流
前端·人工智能
CHANG_THE_WORLD6 小时前
python 批量终止进程exe
开发语言·python
古城小栈6 小时前
从 cargo-whero 库中,找到提升 rust 的契机
开发语言·后端·rust