JavaScript imitates Taobao magnifying glass effect

JavaScript imitates Taobao magnifying glass effect

This article shares the specific code for JavaScript to achieve the Taobao magnifying glass effect for your reference. The specific content is as follows

HTML code

 <div class="thumbnail">
        <img src="./img/12-1Z930152149 (2).jpg" alt="">
        <div class="magnifier"></div>
    </div>
    <div class="original">
        <img src="./img/12-1Z930152149 (2).jpg" alt="">
    </div>
<script src="./index.js"></script>

CSS Code

*{
            margin: 0;
            padding: 0;
        }
        .thumbnail , .original{
            width: 400px;
            height: 400px;
            border: 1px solid red;
            position: absolute;
        }
        .original{
            left: 450px;
            overflow: hidden;
            display: none;
        }
        .thumbnail>img{
            width: 400px;
        }
        .original>img{
            width: 800px;
            position: absolute;
        }
        .magnifier{
            cursor: move;
            width: 200px;
            height: 200px;
            background-color:rgba(206, 198, 198, 0.5);
            position: absolute;
            top: 0;
            left: 0;
            display: none;
            
        }

js code

// thumbnail thumbnail // original original image // magnifier magnifier $(".thumbnail").mouseover(function(){
    $(".magnifier").show()
    $(".original").show()
})
$(".thumbnail").mousemove(function(ev){
    // console.log(ev)
    // Mouse xy coordinates relative to the page var mx = ev.pageX;
    var my =ev.pageY;
    
    var tx = mx - $(".thumbnail").offset().left
    var ty = my - $(".thumbnail").offset().top


    var l = tx -$(".magnifier").width()/2;
    var t = ty -$(".magnifier").height()/2;

    var maxX = $(".thumbnail").width() - $(".magnifier").width();
    var maxY = $(".thumbnail").height() - $(".magnifier").height()

    // Processing boundaries if( l >maxX){
        l = maxX
    }
    if( t >maxY){
        t = maxY
    }
    if(l <0){
        l =0
    }
    if(t<0){
        t=0
    }

    //Magnifying glass position $(".magnifier").css({
        left: l +"px",
        top : t + "px"
    })

    //Original image location$(".original >img").css({
        left:-l*2 +"px",
        top:-t*2 +"px"
    })
})
// Hide the magnifying glass when the mouse leaves the original image$(".thumbnail").mouseout(function(){
    $(".magnifier").hide();
    $(".original").hide();

})

Effect:

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:
  • Implementation process of the magnifying glass effect in the Javascript example project
  • JavaScript realizes magnifying glass special effects
  • JavaScript imitates Jingdong magnifying glass special effects
  • JavaScript object-oriented implementation of magnifying glass case
  • JavaScript imitates Jingdong magnifying glass effect
  • JavaScript to achieve magnifying glass effect
  • Ideas and codes for realizing magnifying glass effect in js
  • JavaScript implementation of magnifying glass details

<<:  How to use CSS to achieve two columns fixed in the middle and adaptive

>>:  Docker Machine in-depth explanation

Recommend

Methods and steps for deploying multiple war packages in Tomcat

1 Background JDK1.8-u181 and Tomcat8.5.53 were in...

How to reference external CSS files and iconfont in WeChat applet wxss

cause The way to import external files into a min...

Detailed explanation of the use of Element el-button button component

1. Background Buttons are very commonly used, and...

mysql5.6.8 source code installation process

Kernel: [root@opop ~]# cat /etc/centos-release Ce...

The solution record of Vue failing to obtain the element for the first time

Preface The solution to the problem of not being ...

Vue implements button switching picture

This article example shares the specific code of ...

How to deploy Rancher with Docker (no pitfalls)

Must read before operation: Note: If you want to ...

Web front-end development CSS related team collaboration

The front-end development department is growing, ...

Comprehensive summary of mysql functions

Table of contents 1. Commonly used string functio...

Detailed explanation of the process of installing msf on Linux system

Or write down the installation process yourself! ...

Collection of 25 fonts used in famous website logos

This article collects the fonts used in the logos...

Detailed explanation of the misunderstanding between MySQL and Oracle

Table of contents Essential Difference Database s...

Detailed explanation of how components communicate in React

1. What is We can split the communication between...

Text mode in IE! Introduction to the role of DOCTYPE

After solving the form auto-fill problem discussed...