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


Posted in Javascript onDecember 08, 2018

本文实例讲述了原生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.3water.com/js/2017/html5-canvas-fangdajing-codes/s1.jpg" /> <!-- 本地图片路径 -->
<span></span> <!-- 鼠标滑动 放大区域 -->
<div class="show"></div>
</div>
<div id="div2"> <!-- 展示放大后的图片 -->
<img id="img1" src="http://demo.3water.com/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.3water.com/code/HtmlJsRun测试运行效果如下:

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

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

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

Javascript 相关文章推荐
vs2003 js文件编码问题的解决方法
Mar 20 Javascript
JavaScript获取和设置CheckBox状态的简单方法
Jul 05 Javascript
node.js应用后台守护进程管理器Forever安装和使用实例
Jun 01 Javascript
js中this的用法实例分析
Jan 10 Javascript
JavaScript操作XML文件之XML读取方法
Jun 09 Javascript
使用AmplifyJS组件配合JavaScript进行编程的指南
Jul 28 Javascript
JS触摸屏网页版仿app弹窗型滚动列表选择器/日期选择器
Oct 30 Javascript
快速实现JS图片懒加载(可视区域加载)示例代码
Jan 04 Javascript
js脚本编写简单刷票投票系统
Jun 27 Javascript
ReactNative短信验证码倒计时控件的实现代码
Jul 20 Javascript
详解vue axios二次封装
Jul 22 Javascript
JS校验与最终登陆界面功能完整示例
Jan 13 Javascript
JS实现的小火箭发射动画效果示例
Dec 08 #Javascript
jQuery时间戳和日期相互转换操作示例
Dec 07 #jQuery
ES6的Fetch异步请求的实现方法
Dec 07 #Javascript
JavaScript this绑定过程深入详解
Dec 07 #Javascript
React 使用recharts实现散点地图的示例代码
Dec 07 #Javascript
如何手动实现es5中的bind方法详解
Dec 07 #Javascript
JavaScript时间与时间戳的转换操作实例分析
Dec 07 #Javascript
You might like
PHP5常用函数列表(分享)
2013/06/07 PHP
PHP正则匹配操作简单示例【preg_match_all应用】
2017/07/10 PHP
利用Homestead快速运行一个Laravel项目的方法详解
2017/11/14 PHP
php中用unset销毁变量并释放内存
2020/05/10 PHP
JavaScript confirm选择判断
2008/10/18 Javascript
一些技巧性实用js代码小结
2009/10/14 Javascript
IE bug table元素的innerHTML
2010/01/11 Javascript
jquery实现图片翻页效果
2013/12/23 Javascript
JavaScript sub方法入门实例(把字符串显示为下标)
2014/10/17 Javascript
跟我学习javascript的arguments对象
2015/11/16 Javascript
jquery按回车键实现表单提交的简单实例
2016/05/25 Javascript
浅析jQuery 3.0中的Data
2016/06/14 Javascript
ES6记录异步函数的执行时间详解
2016/08/31 Javascript
jQuery实现对象转为url参数的方法
2017/01/11 Javascript
js实现导航栏中英文切换效果
2017/01/16 Javascript
详解vue-cli3多环境打包配置
2019/03/28 Javascript
Laravel admin实现消息提醒、播放音频功能
2019/07/10 Javascript
解决layui数据表格Date日期格式的回显Object的问题
2019/09/19 Javascript
浅谈es6中的元编程
2020/12/01 Javascript
详解vue之自行实现派发与广播(dispatch与broadcast)
2021/01/19 Vue.js
[36:02]DOTA2上海特级锦标赛D组小组赛#2 Liquid VS VP第一局
2016/02/28 DOTA
python数据结构之图的实现方法
2015/07/08 Python
Python实现快速计算词频功能示例
2018/06/25 Python
pandas对dataFrame中某一个列的数据进行处理的方法
2019/07/08 Python
QML使用Python的函数过程解析
2019/09/26 Python
Pyorch之numpy与torch之间相互转换方式
2019/12/31 Python
Python pip配置国内源的方法
2020/02/14 Python
Python描述符descriptor使用原理解析
2020/03/21 Python
在Python3.74+PyCharm2020.1 x64中安装使用Kivy的详细教程
2020/08/07 Python
Python根据字符串调用函数过程解析
2020/11/05 Python
解决import tensorflow导致jupyter内核死亡的问题
2021/02/06 Python
市场营销专业毕业生自荐信
2013/11/02 职场文书
会计电算化大学生职业规划书
2014/02/05 职场文书
艺术设计专业个人求职信
2014/04/10 职场文书
民主生活会批评与自我批评总结
2014/10/17 职场文书
合同范本之电脑出租
2019/08/13 职场文书