Vue3 realizes the image magnifying glass effect

Vue3 realizes the image magnifying glass effect

This article example shares the specific code of Vue3 to achieve the image magnifying glass effect for your reference. The specific content is as follows

Achieve results

Code

<template>
  <div class="goods-image">
    <!-- Large image container -->
    <div
      class="large"
      :style="[
        {
          backgroundImage: `url(${imageList[curId]})`,
          backgroundPositionX: position.backgroundPositionX,
          backgroundPositionY: position.backgroundPositionY,
        },
      ]"
      v-if="isShow"
    ></div>
    <div class="middle" ref="target">
      <img :src="imageList[curId]" alt="" />
      <!-- Mask container -->
      <div class="layer" :style="{ left: left + 'px', top: top + 'px' }" v-if="isShow"></div>
    </div>
    <ul class="small">
      <li
        v-for="(img, i) in imageList"
        :key="i"
        @mouseenter="curId = i"
        :class="{ active: curId === i }"
      >
        <img :src="img" alt="" />
      </li>
    </ul>
  </div>
</template>
 
<script>
import { reactive, ref, watch } from 'vue'
import { useMouseInElement } from '@vueuse/core'
export default {
  name: 'GoodsImage',
  props: {
    imageList: {
      type: Array,
      default: () => {
        return []
      }
    }
  },
  setup () {
    const curId = ref(0)
    const target = ref(null)
    // elementX: the offset value of the mouse from the left side // elementY: the offset value of the table from the top // isOutside: whether it is outside the container (true for outside and false for inside)
    const { elementX, elementY, isOutside } = useMouseInElement(target)
    const left = ref(0) // The distance from the slider to the left const top = ref(0) // The distance from the slider to the top const isShow = ref(false) // Show and hide the large image and the mask image const position = reactive({ // The position of the large image display, the default is 0
      backgroundPositionX: 0,
      backgroundPositionY: 0
    })
    watch(
      //Monitoring object [elementX, elementY, isOutside],
      () => {
        if (elementX.value < 100) {
          // Minimum distance on the left left.value = 0
        }
        if (elementX.value > 300) {
          left.value = 200
        }
        if (elementX.value > 100 && elementX.value < 300) {
          left.value = elementX.value - 100
        }
        if (elementY.value < 100) {
          // Minimum distance on the left top.value = 0
        }
        if (elementY.value > 300) {
          top.value = 200
        }
        if (elementY.value > 100 && elementY.value < 300) {
          top.value = elementY.value - 100
        }
        // Control the movement of the background image // 1. The direction of the mask layer's movement is opposite to that of the background image // 2. Since the area ratio of the mask layer and the background image is 1:2, the background image moves two pixels for every pixel the mask layer moves // backgrondPosition: x, y;
        position.backgroundPositionX = -left.value * 2 + 'px'
        position.backgroundPositionY = -top.value * 2 + 'px'
 
        // When the value of isOutside changes, immediately negate it and assign it to isShow
        // isOutside: Is it outside the container? True for outside and false for inside
        isShow.value = !isOutside.value
      },
      {}
    )
    return {
      curId,
      target,
      left,
      top,
      position,
      isShow
    }
  }
}
</script>

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 realizes the product magnifying glass effect
  • Example code of Vue3 encapsulated magnifying glass component
  • Vue implements the magnifying glass function of the product details page
  • Vue implements the magnifying glass effect of tab switching
  • Vue implements a simple magnifying glass effect
  • Vue implements a search box with a magnifying glass
  • Vue3.0 handwriting magnifying glass effect
  • Vue implements magnifying glass effect
  • A handwritten vue magnifying glass effect
  • Vue3 encapsulates the magnifying glass effect component of Jingdong product details page

<<:  Detailed explanation of common operations of Docker images and containers

>>:  Installation of various versions of MySQL 8.0.18 and problems encountered during installation (essence summary)

Recommend

Share the responsive frameworks commonly used by web design masters (summary)

This article introduces and shares the responsive...

How to implement mobile web page size adaptation

I finally finished the project at hand, and the m...

A brief discussion on why daemon off is used when running nginx in docker

I'm very happy. When encountering this proble...

How to recover accidentally deleted messages files in Linux

If there are files that are being used by a proce...

Sharing the structure and expression principles of simple web page layout

Introduction to structure and performance HTML st...

Detailed explanation of how to detect and prevent JavaScript infinite loops

Table of contents Preface Fix infinite loop in fo...

Share 8 very useful CSS development tools

CSS3 Patterns Gallery This CSS3 pattern library s...

Tutorial on logging into MySQL after installing Mysql 5.7.17

The installation of mysql-5.7.17 is introduced be...

Detailed example of using useState in react

useState useState adds some internal state to a c...

How to use vite to build vue3 application

1. Installation Tip: There is currently no offici...

How to use nginx to intercept specified URL requests through regular expressions

nginx server nginx is an excellent web server tha...

Solve the problem of yum installation error Protected multilib versions

Today, when installing nginx on the cloud server,...

How to solve the error "ERROR 1045 (28000)" when logging in to MySQL

Today, I logged into the server and prepared to m...

Vue implements Modal component based on Teleport

Table of contents 1. Get to know Teleport 2. Basi...