11.放大镜.html 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>Document</title>
  7. <style>
  8. * {
  9. margin: 0;
  10. padding: 0;
  11. }
  12. #container {
  13. position: relative;
  14. }
  15. #small {
  16. width: 400px;
  17. height: 400px;
  18. position: relative;
  19. }
  20. #drag {
  21. width: 200px;
  22. height: 200px;
  23. background: rgba(0,0,0,.3);
  24. position: absolute;
  25. top: 0;
  26. left: 0;
  27. display: none;
  28. }
  29. #big {
  30. width: 400px;
  31. height: 400px;
  32. position: absolute;
  33. top: 0;
  34. left: 400px;
  35. overflow: hidden;
  36. display: none;
  37. }
  38. #bigImg {
  39. position: absolute;
  40. }
  41. </style>
  42. </head>
  43. <body>
  44. <div id="container">
  45. <div id="small">
  46. <img src="../../../img/6.jpg" alt="">
  47. <div id="drag"></div>
  48. </div>
  49. <div id="big">
  50. <img id="bigImg" src="../../../img/7.jpg" alt="">
  51. </div>
  52. </div>
  53. <script>
  54. var small = document.getElementById("small");
  55. var drag = document.getElementById("drag");
  56. var big = document.getElementById("big");
  57. var bigImg = document.getElementById("bigImg");
  58. // 鼠标滑入
  59. small.onmouseover = function() {
  60. drag.style.display = "block";
  61. big.style.display = "block";
  62. }
  63. // 鼠标划出
  64. small.onmouseout = function() {
  65. drag.style.display = "none";
  66. big.style.display = "none";
  67. }
  68. // 鼠标移动
  69. small.onmousemove = function(e) {
  70. var smallLeft = e.clientX - drag.offsetWidth / 2;
  71. var smallTop = e.clientY - drag.offsetHeight / 2;
  72. drag.style.left = smallLeft + 'px';
  73. drag.style.top = smallTop + 'px';
  74. if(drag.offsetLeft <= 0) {
  75. drag.style.left = 0;
  76. }
  77. if(drag.offsetTop <= 0) {
  78. drag.style.top = 0;
  79. }
  80. // // 可允许移动的最大范围
  81. var left1 = small.offsetWidth - drag.offsetWidth;
  82. var top1 = small.offsetHeight - drag.offsetHeight;
  83. if(drag.offsetLeft >= left1) {
  84. drag.style.left = left1 + "px";
  85. }
  86. if(drag.offsetTop >= top1) {
  87. drag.style.top = top1 + "px";
  88. }
  89. // 大图允许移动的最大范围
  90. var bigLeft = bigImg.offsetWidth - big.offsetWidth;
  91. var bigTop = bigImg.offsetHeight - big.offsetHeight;
  92. // 比例
  93. var x = drag.offsetLeft / left1;
  94. var y = drag.offsetTop / top1;
  95. // 换算大图移动具体位置
  96. bigImg.style.left = -x * bigLeft + 'px';
  97. bigImg.style.top = -y * bigTop + 'px';
  98. }
  99. </script>
  100. </body>
  101. </html>