jQuery圆形内部放大镜是一种基于jQuery库的图像放大效果插件。它通常用于电商网站的产品展示页面,允许用户在查看商品图片时,通过鼠标悬停在图片的特定区域(通常是圆形区域)来放大显示该区域的细节。
以下是一个简单的jQuery圆形内部放大镜的实现示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>jQuery圆形放大镜</title>
<style>
#magnifier {
position: relative;
width: 300px;
height: 300px;
overflow: hidden;
}
#magnifier img {
width: 100%;
height: auto;
}
.lens {
position: absolute;
border-radius: 50%;
width: 100px;
height: 100px;
background-color: rgba(255, 255, 255, 0.5);
pointer-events: none;
display: none;
}
</style>
</head>
<body>
<div id="magnifier">
<img src="your-image.jpg" alt="Product Image">
<div class="lens"></div>
</div>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script>
$(document).ready(function() {
var magnifier = $('#magnifier');
var lens = magnifier.find('.lens');
var img = magnifier.find('img');
magnifier.on('mousemove', function(e) {
var offset = magnifier.offset();
var x = e.pageX - offset.left;
var y = e.pageY - offset.top;
lens.css({
left: x - lens.width() / 2,
top: y - lens.height() / 2,
display: 'block'
});
var bgPosX = - (x * 2 - lens.width()) / 2;
var bgPosY = - (y * 2 - lens.height()) / 2;
lens.css('background-position', bgPosX + 'px ' + bgPosY + 'px');
}).on('mouseleave', function() {
lens.hide();
});
});
</script>
</body>
</html>
mousemove
事件中的坐标计算,确保放大镜中心跟随鼠标指针。background-position
属性调整背景图像的位置。display
属性设置正确。通过以上方法,可以有效解决jQuery圆形内部放大镜在使用过程中可能遇到的问题。
领取专属 10元无门槛券
手把手带您无忧上云