Detailed explanation of the use of Vue image drag and drop zoom component

Detailed explanation of the use of Vue image drag and drop zoom component

The specific usage of the Vue image drag and drop zoom component is for your reference. The specific content is as follows

<doc>
  Image component - user zooms in and out and drags</doc>
<template>
  <div style="width: 100%;position: relative;overflow: hidden;text-align: center;border: 1px solid #f1f2f3;">
    <el-button size='mini' @click="toBIgChange" icon="el-icon-zoom-in"
      style="position: absolute;top: 2px ;left: 2px;z-index: 999;"></el-button>
    <el-button size='mini' @click="toSmallChange" icon="el-icon-zoom-out"
      style="position: absolute;top: 2px ;left: 40px;z-index: 999;"></el-button>
    <img id="img" :src="src" alt="" @mousedown.prevent="dropImage" :style="{transform:'scale('+multiples+')'}">
  </div>
</template>
<script>
  export default {
    props: ['src'],
    data() {
      return {
        multiples: 1,
        odiv: null,
      }
    },
    mounted() {
      this.dropImage()
    },
    watch:
      src(newValue, oldValue) {
        this.multiples = 1
        if (this.odiv !== null) {
          this.odiv.style.left = '0px';
          this.odiv.style.top = '0px';
        }
      },
    },
    methods: {
      toBIgChange() {
        if (this.multiples >= 2) {
          return;
        }
        this.multiples += 0.25;
      },
      //Shrink toSmallChange() {
        if (this.multiples <= 1) {
          return;
        }
        this.multiples -= 0.25;
      },
      // drag dropImage(e) {
        if (e === null) {
          return
        }
        this.odiv = e.target; //Get the target element //Calculate the position of the mouse relative to the element let disX = e.clientX - this.odiv.offsetLeft;
        let disY = e.clientY - this.odiv.offsetTop;
        document.onmousemove = (e) => { //Mouse pressed and moved event //Subtract the position of the mouse relative to the element from the position of the mouse to get the position of the element let left = e.clientX - disX;
          let top = e.clientY - disY;

          //Bind the element position to positionX and positionY this.positionX = top;
          this.positionY = left;

          //Move the current element this.odiv.style.left = left + 'px';
          this.odiv.style.top = top + 'px';
        };
        document.onmouseup = (e) => {
          document.onmousemove = null;
          document.onmouseup = null;
        };
      },
    }
  }
</script>
<style scoped>
  img {
    width: 100%;
    position: relative;
  }
</style> 

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:
  • Use vue components to realize the drag and zoom function of pictures
  • Vue implements image preview effect example (zoom in, zoom out, drag)
  • Vue implements zoom in, zoom out and drag function
  • Implementing Vue image scaling - dragging components

<<:  How to set the default value of a MySQL field

>>:  Detailed explanation of the deployment process of SEATA transaction service Docker

Recommend

MariaDB-server installation of MySQL series

Table of contents Tutorial Series 1. Install Mari...

SQL to implement time series dislocation restoration case

Table of contents 1. Requirements description 2. ...

A simple way to build a Docker environment

First, let’s understand what Docker is? Docker is...

Some details about semicolons in JavaScript

Preface Semicolons in JavaScript are optional, an...

Detailed explanation of the use of React list bar and shopping cart components

This article example shares the specific code of ...

How to import SQL files in Navicat Premium

I started working on my final project today, but ...

Summary of Linux vi command knowledge points and usage

Detailed explanation of Linux vi command The vi e...

React + Threejs + Swiper complete code to achieve panoramic effect

Let’s take a look at the panoramic view effect: D...

About WSL configuration and modification issues in Docker

https://docs.microsoft.com/en-us/windows/wsl/wsl-...

Detailed explanation of cross-usage of Ref in React

Table of contents 1. First, let’s explain what Re...

Drop-down menu implemented by HTML+CSS3+JS

Achieve results html <div class="containe...

Why is UTF-8 not recommended in MySQL?

I recently encountered a bug where I was trying t...