Vue.js implements the nine-grid image display module

Vue.js implements the nine-grid image display module

I used Vue.js to make a nine-grid image display module, which can be clicked to zoom.

The actual effect of the module

Nine-grid thumbnail effect

After zooming in

Code

HTML

<template>
<div class="SongList">
//Use v-for loop to render thumbnails <div class="covers" :style="{display:MinDisplay}">
         <div class="cover" v-for="(img,index) in imgs" :key='img'><img :src="img.src" width="90%" class="min" @click="ZoomIn(index)" alt=""></div>
       </div>
 // Render the enlarged image <div class="max" :style="{display:display}">
            <div @click="ZoomOut" v-for="(img,index) in imgs" :key='img' :class="[index===ShowIndex?'active':'None']" ><img :src="img.src" width="100%"></div>
            //Navigation map below the enlarged image <div class="small">
                <div :class="[{'smallActive':index===ShowIndex},'cover-small']" v-for="(img,index) in imgs" :key='img' @click="select(index)" ><img :src="img.src" width="90%"></div>
            </div>
        </div>
    </div>
</template>

CSS

<style scoped>
    .SongList{
        width: 40%;
    }
    .covers{
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
    }
    .cover{
        display: flex;
        justify-content: center;
        width: 33%;
        margin: 10px 0;
    }
    .min{
        border-radius: 10px;
        cursor: zoom-in;
    }
    .max{
        cursor: zoom-out;
        width: 100%;

    }
    .small{
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
    }
    .cover-small{
        display: flex;
        justify-content: center;
        width: 10%;
        margin: 10px 0;
        opacity: 0.6;
        cursor: pointer;
    }
    .cover-small:hover{
        opacity: 1;
    }
    .active{
        display: flex;
    }
    .None{
        display: none;
    }
    .smallActive{
        opacity: 1;
    }

</style>

Javascript

<script>
    export default {
        name: "SongList",
        data:function() {
            return {
                ShowIndex:0,
                display: 'none',
                MinDisplay:'flex',
                //When using v-for loop to render images in Vue template, you cannot directly use the local location of the image file imgs:[
                    {"src":require('***.jpg')},
                    {"src":require('***.jpg')},
                    {"src":require('***.jpg')},
                    {"src":require('***.jpg')},
                    {"src":require('***.jpg')},
                    {"src":require('***.jpg')},
                    {"src":require('***.jpg')},
                    {"src":require('***.jpg')},
                    {"src":require('***.jpg')},
                ]

            };
        },
        methods:{
            ZoomIn(i){
               this.display='block';
                this.MinDisplay='none';
                this.ShowIndex=i;
            },
            ZoomOut(){
                this.display='none';
                this.MinDisplay='flex';
            },
            select(i){
                this.ShowIndex=i;


            }
        }
    }

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • Vue component to realize mobile terminal nine-square grid turntable lottery
  • Jiugongge lottery function based on VUE
  • A complete example of a nine-square puzzle game implemented by jQuery+vue.js [with source code download]

<<:  HTML table markup tutorial (41): width and height attributes of the table header WIDTH, HEIGHT

>>:  How to enable Swoole Loader extension on Linux system virtual host

Recommend

Linux uses NetworkManager to randomly generate your MAC address

Nowadays, whether you are on the sofa at home or ...

MySQL sorting feature details

Table of contents 1. Problem scenario 2. Cause An...

JavaScript to achieve balance digital scrolling effect

Table of contents 1. Implementation Background 2....

How does MySQL achieve master-slave synchronization?

Master-slave synchronization, also called master-...

How to find the specified content of a large file in Linux

Think big and small, then redirect. Sometimes Lin...

How to use CSS style to vertically center the font in the table

The method of using CSS style to vertically cente...

jQuery plugin to achieve code rain effect

This article shares the specific code of the jQue...

Detailed explanation of monitoring Jenkins process based on zabbix

1. Monitoring architecture diagram 2. Implementat...

Is mysql a relational database?

MySQL is a relational database management system....

How to add a pop-up bottom action button for element-ui's Select and Cascader

As shown in the figure below, it is a common desi...

Sample code for implementing interface signature with Vue+Springboot

1. Implementation ideas The purpose of interface ...

Usage and execution process of http module in node

What is the role of http in node The responsibili...

mysql 5.6.23 winx64.zip installation detailed tutorial

For detailed documentation on installing the comp...

Detailed example of mysql similar to oracle rownum writing

Rownum is a unique way of writing in Oracle. In O...