js realizes the magnifying glass effect of shopping website products

js realizes the magnifying glass effect of shopping website products

This article shares the specific code of js to achieve the magnifying glass effect of shopping website products for your reference. The specific content is as follows

First, let me explain the principle, taking the magnifying glass effect of a certain product on Tmall as an example:

The so-called magnifying glass effect is actually an effect that deceives our eyes. Here we can see that the row of small pictures below the picture are actually the same as the pictures in the cover layer and the pictures in the magnified layer, but the resolution is different. Therefore, to achieve the magnifying glass effect, we need several groups of pictures with different resolutions but the same content:

Obviously, the small picture is the small picture with "small" in the picture name, the cover layer is the normal-sized picture, and the enlarged layer is the enlarged picture with "big". Then, by adding appropriate displacement and display effects, we can achieve the magnifying glass effect we see. Let's implement it through code:

First write out the HTML structure:

<div id="box">
    <div class="show">
        <img src="./images/1.jpg" alt="#">
        <div class="drag"></div>
    </div>
    <div class="magnify"></div>
    <ul>
        <li class="active"><img src="./images/1.small.jpg" alt="#"></li>
        <li><img src="./images/2.small.jpg" alt="#"></li>
    </ul>
</div>

<script type="text/javascript" src="./javascript/mgfyGlass.js"></script>

<script>
    const oBox = document.querySelector('#box');
    
    const imgArr = [
        {small: '1.small.jpg', normal: '1.jpg', big: '1.big.jpg'},
        {small: '2.small.jpg', normal: '2.jpg', big: '2.big.jpg'}
    ];
</script>

Then add the css style:

body,div,ul,li{
    margin: 0; padding: 0;
    list-style: none;
    font-size: 0;
}
img{
    display: block;
}
#box{
    width: 650px;
    position: relative;
    margin: 0 auto 0 240px;
}
#box .show{
    width: 600px;
    border: solid 2px hotpink;
    position: relative;
}
#box .show img{
    width: 100%;
}
#box .show .drag{
    position: absolute;
    width: 200px;
    height: 200px;
    background-color: #e0a8d7;
    opacity: .4;
    left: 0;
    top: 0;
    display: none;
}
#box .magnify{
    width: 800px;
    height: 800px;
    border: solid 2px #7d777b;
    position: absolute;
    left: 100%;
    top: 0;
    background: url("../images/1.big.jpg") no-repeat 0 0 / 2400px;
    display: none;
}
#box ul{
    width: 100%;
    height: 150px;
    margin-top: 20px;
}
#box ul::after{
    content: '';
    display: block;
    clear: both;
}
#box ul li{
    height: 100%;
    float: left;
    margin: 0 8px;
    border: solid 2px #fff;
}
#box ul li.active{
    border-color: hotpink;
}
#box ul li img{
    height: 100%;
}

Here are some things to note when setting the CSS style:

The magnified layer is enlarged proportionally by the mask layer, so the ratio of the width and height of the magnified layer to the width and height of the mask layer, and the ratio of the size of the magnified layer background image to the size of the normal display image (that is, the image in the class="show" box) are the same.

Here you need to use js to achieve several effects:

1. When the mouse moves into the normal picture box, the cover layer and the magnified layer box are displayed. When the mouse moves out of the normal picture box, the cover layer and the magnified layer box are hidden.
2. Position the cover layer so that it moves with the mouse in the normal image box, and the zoomed-in layer image moves in the zoomed-in layer box accordingly
3. Set the thumbnail switching effect, and when the thumbnail is switched, the normal picture and the enlarged picture are switched to the corresponding picture

Then the code:

class MgnGlass {
    constructor(ele, array) {
        this.ele = ele;
        this.array = array;

        this.show = ele.querySelector('.show');
        this.showImg = this.show.querySelector('img');
        this.drag = ele.querySelector('.drag');
        this.magnify = ele.querySelector('.magnify');
        this.oUl = ele.querySelector('ul');
        this.oUlis = ele.querySelectorAll('ul li');
    }

 // Define a method to call all methods defined later // Entry function init() {
        this.setMouse();
        this.setPosition();
        this.setTab();
    }

    //Mouse movement in and out setMouse() {
     //Mouse over, show the image area, and display the cover layer and magnifying glass this.show.addEventListener('mouseover', () => {
            this.drag.style.display = 'block';
            this.magnify.style.display = 'block';
        });
        //Mouse out, show the image area, hide the cover layer and magnifying glass this.show.addEventListener('mouseout', () => {
            this.drag.style.display = 'none';
            this.magnify.style.display = 'none';
        });
    }

 // Set the positioning effect // When the mouse moves in the image area // 1. Let the cover layer follow the mouse movement---similar to the previous mouse drag effect setPosition() {
        this.show.addEventListener('mousemove', (e) => {
            e = e || event;
            // 1. Position the cover layer // Calculate the coordinate position of the upper left corner of the cover layer by the mouse position let x = e.clientX - this.ele.offsetLeft - this.ele.clientLeft - this.drag.clientWidth / 2;
            let y = e.clientY - this.ele.offsetTop - this.ele.clientTop - this.drag.clientHeight / 2;

   // 2, set the boundary value // minimum is 0 maximum is parent div width and height - cover layer width and height if (x < 0) {
                x = 0;
            }
            else if (x > (this.show.clientWidth - this.drag.clientWidth)){
                x = this.show.clientWidth - this.drag.clientWidth;
            }
            if (y < 0){
                y = 0;
            }
            else if (y > (this.show.clientHeight - this.drag.clientHeight)){
                y = this.show.clientHeight - this.drag.clientHeight;
            }

   // 3, position the value to the cover layer this.drag.style.left = x + 'px';
            this.drag.style.top = y + 'px';

   // 4. The background image of the magnifying glass on the right needs to move together // Add positioning to the background image // The image on the left is stationary, and the cover layer moves Cover layer moves 100 100
            // On the right is the magnifying glass, which is not moving, and the background image is moving. Background image is moving -100 -100
            // When moving, the positioning must be set according to the proportion // Background image positioning = background image size * cover layer positioning / image size // Calculate the background image positioning value by the proportion of the cover layer movement let backX = 2400 * x / 600;
            let backY = 2400 * y / 600;

   // Position the background image // Position the background image this.magnify.style.backgroundPosition = `-${backX}px -${backY}px`;
        })
    }

 // Switching effect // 1. Add style to the label that the mouse is currently over // Remove styles from all labels and add style to the label that is currently clicked/passed over setTab() {
        this.oUlis.forEach((item, key) => {
            item.addEventListener('mouseover', () => {
             // 1, clear the style of all li tags this.oUlis.forEach((item2) => {
                    item2.className = '';
                });
                // 2, add style to the current tag item.className = 'active';

    // 3, set the image // The index subscript key of the current label is the index subscript of the image to be displayed in the corresponding image array // 1, set the path for the image label // Get the corresponding image name through array, index, and image attributes // label.src = assignment or label.setAttribute('src', attribute value) this.showImg.setAttribute('src', `./images/${this.array[key].normal}`);
                // 2. Set the path of the background image for the magnifying glass area. // All settings about the background image must be rewritten this.magnify.style.background = `url('./images/${this.array[key].big}') no-repeat 0 0 / 2400px`;
            })
        })
    }
}

To perfectly achieve the magnifying glass effect, you must pay attention to 2 proportions:

1. CSS style ratio: Image area size: Cover layer size = Background image size: Magnifying glass area size
2. Positioning ratio: Cover layer positioning: Image area size = Background image positioning: Background image size

Then call our constructor to get the final HTML, and execute it to achieve our magnifying glass effect:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width,initial-scale=1.0">
    <title>Magnifying Glass</title>
    <link rel="stylesheet" type="text/css" href="./css/mgfyGlass.css" >
</head>
<body>
    <div id="box">
        <div class="show">
            <img src="./images/1.jpg" alt="#">
            <div class="drag"></div>
        </div>
        <div class="magnify"></div>
        <ul>
            <li class="active"><img src="./images/1.small.jpg" alt="#"></li>
            <li><img src="./images/2.small.jpg" alt="#"></li>
        </ul>
    </div>

    <script type="text/javascript" src="./javascript/mgfyGlass.js"></script>

    <script>
        const oBox = document.querySelector('#box');
        
        const imgArr = [
            {small: '1.small.jpg', normal: '1.jpg', big: '1.big.jpg'},
            {small: '2.small.jpg', normal: '2.jpg', big: '2.big.jpg'}
        ];
        
        const mgnGlass = new MgnGlass(oBox, imgArr);
    
        mgnGlass.init();
    
    
    </script>
</body>
</html>

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:
  • js magnifying glass magnifying picture effect
  • A simple example of using js to achieve the effect of a magnifying glass
  • JavaScript image magnifying glass effect code [the code is relatively simple]
  • A magical Javascript image magnifier
  • JavaScript image magnifier (drag and drop, zoom effect)
  • Magnifying glass effect written in native js
  • Commonly used js magnifying glass effects on e-commerce websites
  • JavaScript image cutting effect (magnifying glass)
  • Image magnifier jquery.jqzoom.js usage example with magnifying glass icon
  • Detailed explanation of the implementation method of js image magnifying glass effect

<<:  Specific use of MySQL binlog_ignore_db parameter

>>:  Docker starts the elasticsearch image and solves the error after mounting the directory

Recommend

Installation and configuration method of Zabbix Agent on Linux platform

Here is a brief summary of the installation and c...

MySQL 5.7.17 installation and configuration method graphic tutorial (windows10)

MySQL 5.7.17 installation and configuration metho...

Implementing file content deduplication and intersection and difference in Linux

1. Data Deduplication In daily work, there may be...

Analyze the working principle of Tomcat

SpringBoot is like a giant python, slowly winding...

How to use HTML form with multiple examples

Nine simple examples analyze the use of HTML form...

JavaScript uses canvas to draw coordinates and lines

This article shares the specific code of using ca...

Implementation of multi-environment configuration (.env) of vue project

Table of contents What is multi-environment confi...

MySql index detailed introduction and correct use method

MySql index detailed introduction and correct use...

Loading animation implemented with CSS3

Achieve results Implementation Code <h1>123...

Realize the CSS loading effect after clicking the button

Since there is a button in my company's produ...

Nginx service 500: Internal Server Error one of the reasons

500 (Internal Server Error) The server encountere...

Web front-end development experience summary

XML files should be encoded in utf-8 as much as p...

What to do if you forget the initial password of MySQL on MAC

The solution to forgetting the initial password o...

How to check where the metadata lock is blocked in MySQL

How to check where the metadata lock is blocked i...

Detailed tutorial on how to automatically install CentOS7.6 using PXE

1. Demand The base has 300 new servers, and needs...