Vue实现图片浏览器

结合之前所学到的v-showv-onv-bind写一个图片浏览器。

整个图片浏览器有两个按钮,"上一张"按钮会切换到上一张图片,"下一张"按钮会切换到下一张。切在第一张图片时,"上一张"按钮会隐去不见;同理,在最后一张图片的时候"下一张"按钮也会隐去。然后中间就显示当前图片。

Vue实例部分需要准备两个变量,一个数据储存图片路径的链接,另一个存放index指向当前正在浏览的图片。

html 复制代码
	<script>
        const app = new Vue({
            el: "#app",
            data: {
                image_list: ["./pic/01.jpg", "./pic/00.jpg", "./pic/02.jpg"],
                index: 0
            }
        })
    </script>

而html中的逻辑也很简单,根据index判断两个按钮是否显示,然后定义点击事件控制index。图片则使用v-bind提供src。

html 复制代码
	<div id="app">
        <button v-show="index > 0" @click="index--">上一张</button>
        <img :src="image_list[index]" alt="龙图" height="124" width="124">
        <button v-show="index < image_list.length-1" @click="index++">下一张</button>
    </div>

完整代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.js"></script>
    <div id="app">
        <button v-show="index > 0" @click="index--">上一张</button>
        <img :src="image_list[index]" alt="龙图" height="124" width="124">
        <button v-show="index < image_list.length-1" @click="index++">下一张</button>
    </div>
    <script>
        const app = new Vue({
            el: "#app",
            data: {
                image_list: ["./pic/01.jpg", "./pic/00.jpg", "./pic/02.jpg"],
                index: 0
            }
        })
    </script>
    
</body>
</html>

效果如图所示,第一张:

第二张:

第三张(最后一张):

相关推荐
yunvwugua__几秒前
Python训练营打卡 Day26
前端·javascript·python
满怀10158 分钟前
【Django全栈开发实战】从零构建企业级Web应用
前端·python·django·orm·web开发·前后端分离
Darling02zjh1 小时前
GUI图形化演示
前端
Channing Lewis1 小时前
如何判断一个网站后端是用什么语言写的
前端·数据库·python
互联网搬砖老肖1 小时前
Web 架构之状态码全解
前端·架构
showmethetime1 小时前
matlab提取脑电数据的五种频域特征指标数值
前端·人工智能·matlab
码农捻旧2 小时前
解决Mongoose “Cannot overwrite model once compiled“ 错误的完整指南
javascript·数据库·mongodb·node.js·express
淡笑沐白2 小时前
探索Turn.js:打造惊艳的3D翻页效果
javascript·html5·turn.js
海上彼尚2 小时前
秒删node_modules[无废话版]
vue.js·react.js
sunxunyong2 小时前
yarn任务筛选spark任务,判断内存/CPU使用超过限制任务
javascript·ajax·spark