JS implementation of picture magnifying glass effect use case
This time I will bring you JS to realize the picture Magnifying glass effectUse cases, what are the Notes for JS to realize the picture magnifying glass effect, the following is a practical case, let's take a look.
Preface
We all often visit various e-commerce websites, and the details of the products require the use of a magnifying glass. This must be familiar to everyone. Today we will make a picture magnifying glass plug-in to see how the picture is enlarged...
Let’s first take a look at what the final effect will be if we achieve it
After reading the effect, do you have any ideas? If not, let’s take a look at how to achieve it~
1 Implementation ideas
① To achieve the effect of zooming in after pointing up, you need to make three ps, one is used to place the original image, the other is used to place the p for the enlargement effect, and the last one is the part of p that needs to be enlarged after the mouse is pointed up (we use this p p tag instead).
② Determine the magnification ratio. The most important point is that the p on the mouse finger and the p of the magnification effect should be equal to the ratio of the original image and the enlarged image.
③ Display the magnification effect after pointing the mouse over.
2 Specific implementation steps
First, let’s build three p’s.
<p> <!--小图--> </p><p> <!--图片--> <img src="/static/imghwm/default1.png" data-src="img/11.png" class="lazy" alt="JS implementation of picture magnifying glass effect use case" > <!--跟随鼠标的白块--> </p><p></p> <!--大图--> <p> <img src="/static/imghwm/default1.png" data-src="img/11.png" class="lazy" alt="JS implementation of picture magnifying glass effect use case" > </p>
Our HTML code part has been completed. Next, we use JS to implement the function:
Add three events to the original image, namely, mouse entry, mouse movement, and mouse movement out.
When the mouse is moved into the original image, the p when the mouse is pointing up and the p of the magnification effect are displayed at the same time.
img1.onmouseover = function () { //鼠标进入 img2.style.display = 'block'; mousebg.style.display = 'block'; }
Mouse out event:
img1.onmouseout = function () { //鼠标离开 img2.style.display = 'none'; mousebg.style.display = 'none'; }
The point is that when the mouse moves, the part of the large image that needs to be enlarged is displayed based on the position of the p tag and the original image.
var _event = event||window.event;//兼容性处理 var mouseX = _event.clientX - img1.offsetLeft; //计算鼠标相对与小图的位置 var mouseY = _event.clientY - img1.offsetTop;
When doing location analysis, four critical situations need to be considered:
That is, when the mouse just enters from the top, bottom, left or right of the picture, and the distance is less than half the width of the p on the mouse finger, the magnified p is displayed and does not move.
//特殊情况处理,分别靠近四条边的时候 if(mouseX<mousebg.offsetwidth>img1.offsetWidth-mousebg.offsetWidth/2){ mouseX = img1.offsetWidth-mousebg.offsetWidth/2; } if(mouseY<mousebg.offsetheight>img1.offsetHeight-mousebg.offsetHeight/2){ mouseY = img1.offsetHeight-mousebg.offsetHeight/2; }</mousebg.offsetheight></mousebg.offsetwidth>
Finally, calculate the display range of the large image:
//计算大图的显示范围 img2_img.style.left = -mul*mouseX+img2.offsetWidth/2+"px"; img2_img.style.top = -mul*mouseY+img2.offsetHeight/2+"px"; //使鼠标在白块的中间 mousebg.style.left = mouseX-mousebg.offsetWidth/2+"px"; mousebg.style.top = mouseY-mousebg.offsetHeight/2+"px";
In this way, we have completed the plug-in for implementing the picture magnifying glass using JS.
I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the php Chinese website!
Recommended reading:
The above is the detailed content of JS implementation of picture magnifying glass effect use case. For more information, please follow other related articles on the PHP Chinese website!

JavaScript core data types are consistent in browsers and Node.js, but are handled differently from the extra types. 1) The global object is window in the browser and global in Node.js. 2) Node.js' unique Buffer object, used to process binary data. 3) There are also differences in performance and time processing, and the code needs to be adjusted according to the environment.

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

The main difference between Python and JavaScript is the type system and application scenarios. 1. Python uses dynamic types, suitable for scientific computing and data analysis. 2. JavaScript adopts weak types and is widely used in front-end and full-stack development. The two have their own advantages in asynchronous programming and performance optimization, and should be decided according to project requirements when choosing.

Whether to choose Python or JavaScript depends on the project type: 1) Choose Python for data science and automation tasks; 2) Choose JavaScript for front-end and full-stack development. Python is favored for its powerful library in data processing and automation, while JavaScript is indispensable for its advantages in web interaction and full-stack development.

Python and JavaScript each have their own advantages, and the choice depends on project needs and personal preferences. 1. Python is easy to learn, with concise syntax, suitable for data science and back-end development, but has a slow execution speed. 2. JavaScript is everywhere in front-end development and has strong asynchronous programming capabilities. Node.js makes it suitable for full-stack development, but the syntax may be complex and error-prone.

JavaScriptisnotbuiltonCorC ;it'saninterpretedlanguagethatrunsonenginesoftenwritteninC .1)JavaScriptwasdesignedasalightweight,interpretedlanguageforwebbrowsers.2)EnginesevolvedfromsimpleinterpreterstoJITcompilers,typicallyinC ,improvingperformance.

JavaScript can be used for front-end and back-end development. The front-end enhances the user experience through DOM operations, and the back-end handles server tasks through Node.js. 1. Front-end example: Change the content of the web page text. 2. Backend example: Create a Node.js server.

Choosing Python or JavaScript should be based on career development, learning curve and ecosystem: 1) Career development: Python is suitable for data science and back-end development, while JavaScript is suitable for front-end and full-stack development. 2) Learning curve: Python syntax is concise and suitable for beginners; JavaScript syntax is flexible. 3) Ecosystem: Python has rich scientific computing libraries, and JavaScript has a powerful front-end framework.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SublimeText3 Chinese version
Chinese version, very easy to use
