打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
js图片放大镜特效代码

以下是HTML中的代码:

<script language="JavaScript">
<!--
var srcX = 1024; //原图长宽
var srcY = 768;
var bigX = 500; //原比例预览大小,可以设置成任意大小
var bigY = 300;
var smallX = 256; //缩略图大小,要与原大小成比例
var smallY = 192;
var viewX = bigX / srcX * smallX; //预览范围
var viewY = bigY / srcY * smallY;
var bl = srcX / smallX;//缩小比例
var border = 8; //边框
window.onload=function (){
    bigbox.style.borderWidth=border;
    bigbox.style.width=bigX+border*2;
    bigbox.style.height=bigY+border*2;
    smallpic.width=smallX;
    smallpic.height=smallY;
    view.style.width=viewX;
    view.style.height=viewY;
    smallbox.style.borderWidth=border;
    if (window.event){
        smallbox.style.width=smallpic.offsetWidth+border*2;
        smallbox.style.height=smallpic.offsetHeight+border*2;
    }else{
        smallbox.style.width=smallpic.offsetWidth;
        smallbox.style.height=smallpic.offsetHeight;
    }
    move(event);
}
function move(e){
    var e = window.event?window.event:e;
    var iebug = 0;
    if (window.event){
        var vX = e.offsetX - viewX/2;
        var vY = e.offsetY - viewY/2;
    }else{
        var vX = e.pageX - viewX/2 - smallbox.offsetLeft - border;
        var vY = e.pageY - viewY/2 - smallbox.offsetTop - border;
        iebug = 2;
    }
    if (vX < 0) vX = 0;
    if (vY < 0) vY = 0;
    if (vX > smallX - viewX - iebug) vX = smallX - viewX - iebug;
    if (vY > smallY - viewY - iebug) vY = smallY - viewY - iebug;
    view.style.left = vX + smallbox.offsetLeft + border;
    view.style.top = vY + smallbox.offsetTop + border;
    bigbox.style.backgroundPosition= - vX * bl + " " + -vY * bl;
}
//-->
</script>


<style type="text/css">
<!--
*{padding:0;margin:0}
img{display:block;}
#smallbox{border:1px #c33 solid;float:left;width:0;height:0;overflow:hidden}
#bigbox{border:1px #c33 solid;width:0px;height:0px;float:left;background:url('/upload/20071130224657571.jpg') no-repeat;}
#view{border:1px #ddd solid;width:0px;height:0px;position:absolute}
.head{text-align:center;line-height:40px;font:bold 16px/40px;color:red}
//-->
</style>
<div class="head">图片放大效果</div>
<div id="smallbox"><img id="smallpic" src="/upload/20071130224657571.jpg" border="0" onmousemove="move(event)"></div>
<div id="bigbox"></div>
<div id="view"></div>

代码最终的效果如下图:

您可以根据需要修改图片的链接地址。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
AS3 跟随鼠标的缓动
用.NET模拟天体运动
头上安头,是给自己造下一个再生缘。。
千眼玉米雕刻教程
点击欣赏代码
【自制绘本】《山兽来啦》——南山经之首鹊山山系
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服