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/vue@2.7.14/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>

效果如图所示,第一张:

第二张:

第三张(最后一张):

相关推荐
不说别的就是很菜13 小时前
【前端面试】CSS篇
前端·css·面试
by__csdn13 小时前
nvm安装部分node版本后没有npm的问题(14及以下版本)
前端·npm·node.js
by__csdn13 小时前
Node与Npm国内最新镜像配置(淘宝镜像/清华大学镜像)
前端·npm·node.js
脸大是真的好~13 小时前
黑马JAVAWeb -Vue工程化-API风格 - 组合式API
前端·javascript·vue.js
我命由我1234513 小时前
CesiumJS 案例 P35:添加图片图层(添加图片数据)
开发语言·前端·javascript·css·html·html5·js
你挚爱的强哥13 小时前
【sgMobileUploadTypeSelect】自定义组件:从底部弹出选择上传图片文件的方式【1、上传本地文件,2、拍摄上传】
前端·javascript·vue.js
Mike_jia14 小时前
Checkmate:自建监控新标杆!开源替代Zabbix的轻量级方案实战
前端
fury_12314 小时前
tsfile.raw提示
java·前端·javascript
喝拿铁写前端14 小时前
从面条代码到抽象能力:一个小表单场景里的前端成长四阶段
前端·设计模式·架构
LXA080914 小时前
Vue 3中使用JSX
前端·javascript·vue.js