17.放大镜.html 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  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. #small img {
  21. width: 100%;
  22. height: 100%;
  23. }
  24. #big {
  25. width: 400px;
  26. height: 400px;
  27. position: absolute;
  28. top: 0;
  29. left: 400px;
  30. display: none;
  31. overflow: hidden;
  32. }
  33. #drag {
  34. width: 200px;
  35. height: 200px;
  36. background: rgba(0,0,0,.3);
  37. position: absolute;
  38. top: 0;
  39. left: 0;
  40. display: none;
  41. }
  42. #pictures {
  43. position: absolute;
  44. }
  45. </style>
  46. </head>
  47. <body>
  48. <div id="container">
  49. <div id="small">
  50. <img src="./images/6.jpg" alt="">
  51. <div id="drag"></div>
  52. </div>
  53. <div id="big">
  54. <img src="./images/7.jpg" id="pictures" alt="">
  55. </div>
  56. </div>
  57. <script>
  58. var small = document.getElementById("small");
  59. var drag = document.getElementById("drag");
  60. var big = document.getElementById("big");
  61. var pictures = document.getElementById("pictures");
  62. small.onmouseover = function() {
  63. big.style.display = 'block';
  64. drag.style.display = 'block';
  65. }
  66. small.onmouseout = function() {
  67. big.style.display = 'none';
  68. drag.style.display = 'none';
  69. }
  70. small.onmousemove = function(event) {
  71. var left1 = event.clientX - drag.offsetWidth / 2;
  72. var top1 = event.clientY - drag.offsetHeight / 2;
  73. drag.style.left = left1 + 'px';
  74. drag.style.top = top1 + 'px';
  75. if(drag.offsetTop <= 0) {
  76. drag.style.top = 0;
  77. }
  78. if(drag.offsetLeft <= 0) {
  79. drag.style.left = 0;
  80. }
  81. var left2 = small.offsetWidth - drag.offsetWidth;
  82. var top2 = small.offsetHeight - drag.offsetHeight;
  83. if(drag.offsetTop > top2) {
  84. drag.style.top = top2 + 'px';
  85. }
  86. if(drag.offsetLeft > left2) {
  87. drag.style.left = left2 + 'px';
  88. }
  89. var bigLeft = pictures.offsetWidth - big.offsetWidth;
  90. var bigTop = pictures.offsetHeight - big.offsetHeight;
  91. var x = drag.offsetLeft / left2;
  92. var y = drag.offsetTop / top2;
  93. pictures.style.top = -bigTop * y + 'px';
  94. pictures.style.left = -bigLeft * x + 'px';
  95. }
  96. </script>
  97. </body>
  98. </html>