前端代码实现放大镜效果

利用css和js实现页面放大镜效果
像一些淘宝等购物商场
商品放大镜 可以更为清晰地观看喜欢的物品

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			*{
				margin: 0;
				padding: 0;
			}
			.yuantu{
				width: 300px;
				height: 300px;
				float: left;
				margin-top: 100px;
				margin-left: 100px;
				position: relative;
				cursor: move;
			}
			img{
				width: 100%;
				height: 100%;
			}
			.fangdatu{
				width: 300px;
				height: 300px;
				float: left;
				margin-top: 100px;
				display: none;
				overflow: hidden;
				position: relative;
			}
			.fangdatu img{
				width: 200%;
				height: 200%;
				position: absolute;
			}
			.fdj{
				width: 100px;
				height: 100px;
				opacity: 0.5;
				background: red;
				position: absolute;
				left: 0;
				top: 0;
				display: none;
			}
			.m{
				display: block;
			}
		</style>
	</head>
	<body>
		<div class="yuantu">
			<img src="imgs/01.jpg"/>
			<div class="fdj"></div>
		</div>
		<div class="fangdatu">
			<img src="imgs/01.jpg"/>
		</div>
	</body>
	<script type="text/javascript">
		var yuantu = document.getElementsByClassName("yuantu")[0];
		var fangdatu = document.getElementsByClassName("fangdatu")[0];
		var fdj = document.getElementsByClassName("fdj")[0];
		var img = document.getElementsByTagName("img")[1];
		/*鼠标悬停*/
		yuantu.onmouseenter = function () {
			fdj.className = "fdj m";
			fangdatu.className = "fangdatu m"
		}
		/*鼠标离开*/
		yuantu.onmouseleave = function () {
			fdj.className = "fdj";
			fangdatu.className = "fangdatu"
		}
		/*鼠标移动 监听鼠标位置*/
		yuantu.onmousemove = function (event) {
			var event = event||window.event;
			
			x= event.pageX-yuantu.offsetLeft-fdj.offsetWidth/2;
			y= event.pageY-yuantu.offsetTop-fdj.offsetHeight/2;
			
			if(x<0){
				x=0;
			};
			if(y<0){
				y=0;
			};
			if(x>this.offsetWidth-fdj.offsetWidth){
				x=this.offsetWidth-fdj.offsetWidth;
			};
			if(y>this.offsetHeight-fdj.offsetHeight){
				y=this.offsetHeight-fdj.offsetHeight;
			};
			
			
			fdj.style.left = x+"px";
			fdj.style.top = y+"px";
			
			img.style.left = -x*2+"px";
			img.style.top = -y*2+"px";
		}
	</script>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,对于前端文字放大镜功能,我可以为您提供以下方法: 1. 使用CSS的transform:scale属性可以实现文字放大效果,样式如下: ``` .text { font-size: 16px; /* 正常字体大小 */ transition: transform 0.3s ease-in-out; /* 动画效果 */ } .text:hover { transform: scale(1.2); /* 悬浮时字体放大1.2倍 */ } ``` 2. 也可以使用JavascriptCSS控制鼠标位置和字体放大倍数来实现放大镜效果代码如下: HTML: ``` <div class="container"> <div class="text" id="text">Some text</div> <div class="magnifier" id="magnifier"></div> </div> ``` CSS: ``` .container { position: relative; width: 100%; height: 300px; } .text { position: absolute; top: 0; left: 0; font-size: 16px; overflow: hidden; height: 100%; } .magnifier { position: absolute; top: 0; left: 0; width: 100px; height: 100px; border: 1px solid #ccc; border-radius: 50%; background: rgba(0,0,0,.2); pointer-events: none; display: none; } ``` Javascript: ``` var container = document.querySelector('.container'), text = document.querySelector('#text'), magnifier = document.querySelector('#magnifier'); container.addEventListener('mousemove', function(e) { var rect = container.getBoundingClientRect(), x = e.clientX - rect.left, y = e.clientY - rect.top, offsetX = x / container.offsetWidth, offsetY = y / container.offsetHeight, textWidth = text.offsetWidth, textHeight = text.offsetHeight, magWidth = magnifier.offsetWidth, magHeight = magnifier.offsetHeight; magnifier.style.left = (x - magWidth / 2) + 'px'; magnifier.style.top = (y - magHeight / 2) + 'px'; magnifier.style.display = 'block'; text.style.transform = 'translate(-' + offsetX * (textWidth - container.offsetWidth) + 'px, -' + offsetY * (textHeight - container.offsetHeight) + 'px)'; magnifier.style.backgroundPosition = '-' + (x - magWidth / 2) * 2 + 'px -' + (y - magHeight / 2) * 2 + 'px'; }); container.addEventListener('mouseleave', function() { magnifier.style.display = 'none'; }); ``` 希望以上方法能够帮助到您!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值