JS实现放大镜功能,鼠标经过一个图片,放大显示

<style type="text/css">
        #magnifier
        {
            width: 210px;
            height: 200px;
            position: absolute;
            top: 10px;
            left: 438px;
            font-size: 0;
            border: 1px solid #000;
        }
        #img
        {
            width: 342px;
            height: 420px;
        }
        #Browser
        {
            border: 1px solid #000;
            z-index: 100;
            position: absolute;
            background: #555;
        }
        #mag
        {
            border: 1px solid #000;
            overflow: hidden;
            z-index: 100;
        }
    </style>

    <script type="text/javascript">
        function getEventObject(W3CEvent) {   //事件标准化函数
            return W3CEvent || window.event;
        }
        function getPointerPosition(e) {   //兼容浏览器的鼠标x,y获得函数
            e = e || getEventObject(e);
            var x = e.pageX || (e.clientX + (document.documentElement.scrollLeft || document.body.scrollLeft));
            var y = e.pageY || (e.clientY + (document.documentElement.scrollTop || document.body.scrollTop));

            return { 'x': x, 'y': y };
        }
        function setOpacity(elem, level) {   //兼容浏览器设置透明值
            if (elem.filters) {
                elem.style.filter = 'alpha(opacity=' + level * 100 + &#

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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. 也可以使用Javascript和CSS控制鼠标位置和字体放大倍数来实现放大镜效果,代码如下: 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、付费专栏及课程。

余额充值