实现功能:

模仿淘宝图片放大效果,鼠标移动到小图片的某一处,放大镜对应显示大图片的相应位置。

实现效果:

实现代码:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>图片放大镜效果</title>
  6. <script type="text/javascript" src="../js/jquery-3.2.1.min.js" ></script>
  7. <style>
  8. .min{
  9. width: 350px;
  10. height: 350px;
  11. border: 1px solid black;
  12. float: left;
  13. position: relative;
  14. margin: 50px 0 0 30px;
  15.  
  16. }
  17. .max{
  18. width: 350px;
  19. height: 350px;
  20. border: 1px solid black;
  21. float: left;
  22. display: none;
  23. overflow: hidden;
  24. position: relative;
  25. margin-left:30px ;
  26. }
  27. .max img{
  28. position: absolute;
  29. margin: 0 auto;
  30. }
  31. .fd{
  32. width: 153.125px;
  33. height: 153.125px;
  34. background-color: skyblue;
  35. opacity: 0.3;
  36. position: absolute;
  37. top: 0;
  38. left: 0;
  39. display: none;
  40. cursor: move;
  41. }
  42. </style>
  43. </head>
  44. <body>
  45. <div class="min">
  46. <img src="../img/0.jpg" width="350px" height="350px"/>
  47. <div class="fd"></div>
  48. </div>
  49. <div class="max">
  50. <img src="../img/0.jpg"/>
  51. </div>
  52.  
  53. <script>
  54. var min = document.querySelector(".min");
  55. var max = document.querySelector(".max");
  56. var img = document.querySelector(".max img");
  57. var fd = document.querySelector(".fd");
  58.  
  59. min.onmouseover = function(){
  60. // 1.鼠标覆盖显示max和fd
  61. max.style.display = "block";
  62. fd.style.display = "block";
  63. }
  64. // 离开时隐藏
  65. min.onmouseout = function(){
  66. max.style.display = "none";
  67. fd.style.display = "none";
  68. }
  69. // 2. fd的移动范围
  70. min.onmousemove = function(){
  71. // 鼠标触摸的点
  72. var x = event.clientX-min.offsetLeft-fd.offsetWidth/2;
  73. var y = event.clientY-min.offsetTop-fd.offsetHeight/2;
  74. // 最大移动距离
  75. var maxX = min.clientWidth-fd.offsetWidth;
  76. var maxY = min.clientHeight-fd.offsetHeight;
  77. // 边界判断
  78. if (x <= 0) {
  79. x = 0;
  80. }else if (x >= maxX) {
  81. x = maxX;
  82. }
  83. if (y <= 0) {
  84. y = 0;
  85. }else if (y >= maxY) {
  86. y = maxY;
  87. }
  88. // fd的位置
  89. fd.style.left = x+'px';
  90. fd.style.top = y+'px';
  91. //fd/min = max/img
  92. //移动比例
  93. var moveX = x/maxX;
  94. var moveY = y/maxY;
  95. // 移动
  96. // 3. max的对应显示
  97. // 对于大图而言,放大镜在小图上移动的比例相当于img在可显示区域上移动的比例
  98. // 放大镜右移等于图片左移
  99. // 也就是本质上为img-max 然而而需要负值,则*-1简化后为max-img
  100. img.style.left = moveX*(max.clientWidth - img.offsetWidth) + 'px';
  101. img.style.top = moveY*(max.clientHeight - img.offsetHeight) + 'px';
  102.  
  103. }
  104.  
  105. </script>
  106. </body>
  107. </html>

【Demo】jQuery 图片放大镜效果——模仿淘宝图片放大效果的更多相关文章

  1. Jquery图片放大镜

    一般在“在线商城.电子商务.企业产品介绍”等地方经常会看到一些图片放大镜的功能,而做这个功能一般是会用一个js包——enlarge.js(这是jquery图片放大镜的插件).Enlarge 是一个基于 ...

  2. jquery图片放大镜和遮罩层效果

    图片放大镜效果将借助于jqzoom插件,遮罩层借助于thickbox插件. 1.引入样式表 /*整体样式*/ <link rel="stylesheet" href=&quo ...

  3. jquery图片查看插件,支持旋转、放大、缩小、拖拽、缩略图(仿qq图片查看)

    最近做了一个jquery图片查看的插件,目的是能精确查看图片的详情,插件支持图片旋转.放大.缩小.拖拽.缩略图显示,界面效果是按照window的qq查看图片功能写的,当然不尽相同. 具体功能: 1. ...

  4. 原生javascript实现图片放大镜效果

    当我们在电商网站上购买商品时,经常会看到这样一种效果,当我们把鼠标放到我们浏览的商品图片上时,会出现类似放大镜一样的一定区域的放大效果,方便消费者观察商品.今天我对这一技术,进行简单实现,实现图片放大 ...

  5. 仿淘宝分页按钮效果简单美观易使用的JS分页控件

    分页按钮思想:  1.少于9页,全部显示  2.大于9页,1.2页显示,中间页码当前页为中心,前后各留两个页码  附件中有完整例子的压缩包下载.已更新到最新版本  先看效果图:  01输入框焦点效果  ...

  6. 漂亮!Javascript代码模仿淘宝宝贝搜索结果的分页显示效果

    分页按钮思想: 1.少于9页,全部显示 2.大于9页,1.2页显示,中间页码当前页为中心,前后各留两个页码 先看效果图: 01输入框焦点效果 02效果 模仿淘宝的分页按钮效果控件kkpager  JS ...

  7. Jquery插件开发之图片放大镜效果(仿淘宝)

    原网转载地址:http://www.cnblogs.com/hnvvv/archive/2011/11/19/2255197.html 需求:公司某个网站,需要实现图片预览效果,并能像淘宝一样实现局部 ...

  8. 基于jQuery仿淘宝产品图片放大镜代码

    今天给大家分享一款 基于jQuery淘宝产品图片放大镜代码.这是一款基于jquery.imagezoom插件实现的jQuery放大镜.适用浏览器:IE8.360.FireFox.Chrome.Safa ...

  9. 基于jQuery仿淘宝产品图片放大镜特效

    在开发商城的时候,往往会用到图片的放大功能,这里把自己在近期项目中使用的放大镜特效做一下总结(非插件). 放大镜效果 常用的js组件jquery.imagezoom,jquery.jqzoom,jqu ...

随机推荐

  1. Code Forces 18D Seller Bob(简单DP)

    D. Seller Bob time limit per test 2 seconds memory limit per test 128 megabytes input standard input ...

  2. Oracle安装部署之 6节点11g cluster环境搭建

    **********************集群规划*************************************** --配置主机,共需要8台主机,其中6台做grid集群,1台作为存储服 ...

  3. Eclipse For Android 代码自动提示功能

    Eclipse for android 实现代码自动提示智能提示功能,介绍 Eclipse for android 编辑器中实现两种主要文件 java 与 xml 代码自动提示功能,解决 eclips ...

  4. mybatis-spring-boot-autoconfigure

    mybatis-spring-boot-autoconfigure – MyBatis Sring-BootStarter | Reference Documentation http://www.m ...

  5. rpc、socket、mq

    关于RPC与MQ异同的理解 相同:1.都利于大型系统的解耦:2.都提供子系统之间的交互,特别是异构子系统(如java\node等不同开发语言):不同:1.RPC侧重功能调用,因此多半是同步的:备注:也 ...

  6. web前端开发http-server

    windows环境下需先安装npm 安装 npm install -g http-server http-server -a hostip -p port

  7. python开发之路目录

    Python 目录 基础 python入门 python数据类型.字符编码.文件处理 python函数基础 python函数进阶 python装饰器函数 python装饰器函数 python递归函数 ...

  8. 3.11 Templates --Rendering with Helpers

    Ember提供几个辅助器允许你使用不同的方法渲染模板(render templates). 一.The {{partial}} Helper {{partial}}以呈现的模板作为参数,并在这里呈现模 ...

  9. 4.10 Routing -- Asynchronous Routing

    本节介绍了路由器的一些更高级的功能和处理复杂异步逻辑的能力. 一.A word on promises 1. 在Ember的Router中Ember使用了大量的Promises概念来处理异步逻辑.简而 ...

  10. visio基础教程(一)