欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

原生JS实现的放大镜特效示例【测试可用】

程序员文章站 2024-01-05 23:27:04
本文实例讲述了原生js实现的放大镜特效。分享给大家供大家参考,具体如下: 最近在做ecshop的二次开发,遇到一些jquery插件与ecshop的冲突, 调整冲突的需要...

本文实例讲述了原生js实现的放大镜特效。分享给大家供大家参考,具体如下:

最近在做ecshop的二次开发,遇到一些jquery插件与ecshop的冲突,

调整冲突的需要修改的地方又太多,修改起来得不偿失,

故做了一个原生的js实现商品详情页面的放大镜效果,以避免冲突!

下面介绍一下代码及实现过程:

首先,创建fangda.html文件

在文件头部的<head></head>中添加文件的css样式,即:

<style type="text/css">
#div1 { width:304px; height:222px; position:relative; margin:30px auto 0px; border:2px solid red;}
#div1 img{width:304px; height:222px;}
#div1 span { width:100px; height:100px; background:red; left:0px;top:0px; position:absolute; display:none; filter:alpha(opacity:20); opacity:0.2;}
.show { width:100%; height:100%; background:red; position:absolute; z-index:10px; filter:alpha(opacity:10); opacity:0.1; left:0px; top:0px; }
#div2 {width:304px; height:222px; position:relative; display:none; overflow:hidden; margin:0px auto 0px;}
#img1 { position:absolute;}
</style>

设置,显示在页面的内容

<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>javascript 图片放大代码</title>
<body>
<div id="div1">
<img src="http://demo.jb51.net/js/2017/html5-canvas-fangdajing-codes/s1.jpg" /> <!-- 本地图片路径 -->
<span></span> <!-- 鼠标滑动 放大区域 -->
<div class="show"></div>
</div>
<div id="div2"> <!-- 展示放大后的图片 -->
<img id="img1" src="http://demo.jb51.net/js/2017/html5-canvas-fangdajing-codes/s1.jpg" /> <!-- 本地大图片路径 -->
</div>
</body>

然后,添加js事件效果,添加在<head></head>

<script type="text/javascript">
//通过页面加载事件,使页面加载完毕自动执行
window.onload=function ()
{
var odiv=document.getelementbyid('div1');
var oshow=odiv.getelementsbytagname('div')[0];
var ospan=odiv.getelementsbytagname('span')[0];
var oimg=document.getelementbyid('img1');
oshow.onmouseover=function()
{
ospan.style.display='block';
oimg.parentnode.style.display='block';
};
oshow.onmouseout=function()
{
ospan.style.display='none';
oimg.parentnode.style.display='none';
};
oshow.onmousemove=function(ev)
{
var oevent=ev||event;
var x=oevent.clientx-odiv.offsetleft-ospan.offsetwidth/2;
var y=oevent.clienty-odiv.offsettop-ospan.offsetheight/2;
//获得具体坐标
if(x<0)
{
x=0;
}
else if(x>oshow.offsetwidth-ospan.offsetwidth)
{
x=oshow.offsetwidth-ospan.offsetwidth;
}
if(y<0)
{
y=0;
}
else if(y>oshow.offsetheight-ospan.offsetheight)
{
y=oshow.offsetheight-ospan.offsetheight
}
ospan.style.left=x+'px';
ospan.style.top=y+'px';
var percentx=x/(oshow.offsetwidth-ospan.offsetwidth);
var percenty=y/(oshow.offsetheight-ospan.offsetheight);
var oimgparent=oimg.parentnode;
oimg.style.left=-percentx*(oimg.offsetwidth-oimgparent.offsetwidth)+'px';
oimg.style.top=-percenty*(oimg.offsetheight-oimgparent.offsetheight)+'px';
};
};
</script>

这样就实现了,图片移上后的放大效果,同时由于没有引入其他的插件,移植性比较好,可以通过更改较少的代码,就较好地规避在其他项目和商城中的冲突。

但缺点没有引入插件后效果华丽,加载页面没有引入插件的快,

可以考虑在这个页面做一个缓存,增加用户二次访问速度!

这里使用在线html/css/javascript代码运行工具http://tools.jb51.net/code/htmljsrun测试运行效果如下:

 原生JS实现的放大镜特效示例【测试可用】

感兴趣的朋友可以使用上述在线工具测试一下看看运行效果。

更多关于javascript相关内容感兴趣的读者可查看本站专题:《javascript图片操作技巧大全》、《javascript运动效果与技巧汇总》、《javascript切换特效与技巧总结》、《javascript错误与调试技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》及《javascript数学运算用法总结

希望本文所述对大家javascript程序设计有所帮助。

上一篇:

下一篇: