[removed] Zoom in on mouseover WITHOUT Jquery or plugins

前端 未结 4 947
梦如初夏
梦如初夏 2020-12-14 09:24

I\'ve looked for this everywhere for weeks, and I simply cannot find something to tell me what I\'m doing wrong or how to even proceed. The goal is to create a function simi

相关标签:
4条回答
  • 2020-12-14 09:53

    try this

    window.addEventListener("load", imageZoom("my-image"));
    
    function imageZoom(imgID) {
        let img, lens, result, cx, cy;
        img = document.getElementById(imgID);
        result = document.getElementById("my-result");
        lens = document.querySelector(".img-zoom-lens");
        cx = result.offsetWidth / lens.offsetWidth;
        cy = result.offsetHeight / lens.offsetHeight;
        result.style.backgroundImage = "url('" + img.src + "')";
        result.style.backgroundSize = (img.width * cx) + "px " + (img.height * cy) + "px";
        lens.addEventListener("mousemove", moveLens);
        img.addEventListener("mousemove", moveLens);
        lens.addEventListener("touchmove", moveLens);
        img.addEventListener("touchmove", moveLens);
        function moveLens(e) {
            let pos, x, y;
            e.preventDefault();
            pos = getCursorPos(e);
            x = pos.x - (lens.offsetWidth / 2);
            y = pos.y - (lens.offsetHeight / 2);
            if (x > img.width - lens.offsetWidth) {x = img.width - lens.offsetWidth;}
            if (x < 0) {x = 0;}
            if (y > img.height - lens.offsetHeight) {y = img.height - lens.offsetHeight;}
            if (y < 0) {y = 0;}
            lens.style.left = x + "px";
            lens.style.top = y + "px";
            result.style.backgroundPosition = "-" + (x * cx) + "px -" + (y * cy) + "px";
        }
        function getCursorPos(e) {
            let a, x = 0, y = 0;
            e = e || window.event;
            a = img.getBoundingClientRect();
            x = e.pageX - a.left;
            y = e.pageY - a.top;
            x = x - window.pageXOffset;
            y = y - window.pageYOffset;
            return {x : x, y : y};
        }
    }
    
    // Function to change Images
    (function () {
      let originalImg = document.querySelector("#my-image");
      let galleryImg = document.querySelector(".img-gallery").children;
    
      for(let i = 0; i < galleryImg.length; i++) {
        galleryImg[i].onclick = function() {
          originalImg.setAttribute("src", this.getAttribute("src"));
          imageZoom("my-image");
        };
      }
    })();
    * {
      box-sizing: border-box;
      font-family: sans-serif;
    }
    
    .img-container {
      position: relative;
      display: flex;
      justify-content: space-between;
    }
    
    .img-zoom-lens {
      position: absolute;
      border: 3px solid rgb(0, 126, 255);
      background-color: rgba(0, 126, 255, .2);
      width: 40px;
      height: 40px;
    }
    
    #my-image {
      max-width: 50%;
      height: 300px;
    }
    
    .img-zoom-result {
      border: 1px solid #f1f1f1;
      width: 300px;
      height: 300px;
    }
    
    .img-gallery {
      margin: 16px 0;
    }
    
    .img-gallery img {
      display: inline-block;
      cursor: pointer;
      width: 110px;
      height: 110px;
      border: 1px solid #ccc;
      padding: 4px;
      margin-right: 8px;
    }
    
    .img-gallery img:active {
      box-shadow: 0 0 0.1rem 0.1rem rgba(38,143,255,.5);
    }
    
    .img-gallery img:focus {
      box-shadow: 0 0 0.1rem 0.1rem rgba(38,143,255,.5);
    }
    <h1>Create an Image Zoom</h1>
    
    <div class="img-container">
      <div class="img-zoom-lens"></div>
      <img id="my-image" src="https://parrot-tutorial.com/images/carousel_red3.jpg">
      <div id="my-result" class="img-zoom-result"></div>
    </div>
    
    <p>Choose more images:</p>
    <div class="img-gallery">
        <img src="https://parrot-tutorial.com/images/avatar.jpg">
        <img src="https://parrot-tutorial.com/images/bottleship.jpg">
        <img src="https://parrot-tutorial.com/images/toxic.jpg">
    </div>

    Reference:Create an Image Zoom

    0 讨论(0)
  • 2020-12-14 10:03

    function zoomIn(event) {
      var element = document.getElementById("overlay");
      element.style.display = "inline-block";
      var img = document.getElementById("imgZoom");
      var posX = event.offsetX ? (event.offsetX) : event.pageX - img.offsetLeft;
      var posY = event.offsetY ? (event.offsetY) : event.pageY - img.offsetTop;
      element.style.backgroundPosition = (-posX * 4) + "px " + (-posY * 4) + "px";
    
    }
    
    function zoomOut() {
      var element = document.getElementById("overlay");
      element.style.display = "none";
    }
    #overlay {
      border: 1px solid black;
      width: 100px;
      height: 100px;
      display: inline-block;
      background-image: url('http://ginger-mum.com/wp-content/uploads/2015/10/3633-1269758855-0da5042c33400a811a5d766be4579cb8.jpg');
      background-repeat: no-repeat;
    }
    <img id="imgZoom" width="200px" height="200px" onmousemove="zoomIn(event)" onmouseout="zoomOut()" src="http://ginger-mum.com/wp-content/uploads/2015/10/3633-1269758855-0da5042c33400a811a5d766be4579cb8.jpg">
    <div id="overlay" onmousemove="zoomIn(event)"></div>

    0 讨论(0)
  • 2020-12-14 10:09

    you can just do it by playing background-position on mouse-over just moving background-position on mouseover DEMO

    function zoomIn(event) {
      var element = document.getElementById("overlay");
      element.style.display = "inline-block";
      var img = document.getElementById("imgZoom");
      var posX = event.offsetX ? (event.offsetX) : event.pageX - img.offsetLeft;
      var posY = event.offsetY ? (event.offsetY) : event.pageY - img.offsetTop;
      element.style.backgroundPosition = (-posX * 4) + "px " + (-posY * 4) + "px";
    
    }
    
    function zoomOut() {
      var element = document.getElementById("overlay");
      element.style.display = "none";
    }
    #overlay {
      border: 1px solid black;
      width: 200px;
      height: 200px;
      display: inline-block;
      background-image: url('http://ginger-mum.com/wp-content/uploads/2015/10/3633-1269758855-0da5042c33400a811a5d766be4579cb8.jpg');
      background-repeat: no-repeat;
    }
    <img id="imgZoom" width="200px" height="200px" onmousemove="zoomIn(event)" onmouseout="zoomOut()" src="http://ginger-mum.com/wp-content/uploads/2015/10/3633-1269758855-0da5042c33400a811a5d766be4579cb8.jpg">
    <div id="overlay" onmousemove="zoomIn(event)"></div>

    0 讨论(0)
  • 2020-12-14 10:10

    This works for me: (Here is a JSFiddle)

    #imgZoom {
        height: 300;
    }
    img#imgZoom:hover {
        position: relative;
        -webkit-transform: scale(1.5);
        -ms-transform: scale(1.5);
        -o-transform: scale(1.5);
        transform: scale(1.5);
        z-index: 1000;
    }
    

    You can also add this for a cool transition effect:

    * {
        -webkit-transition: all 0.5s ease-in-out;
        -moz-transition: all 0.5s ease-in-out;
        -ms-transition: all 0.5s ease-in-out;
        -o-transition: all 0.5s ease-in-out;
        transition: all 0.5s ease-in-out;
    }
    

    *Also, you can apply the same logic not only for images, but for divs as well.

    0 讨论(0)
提交回复
热议问题