How to do zoom on an image while a mouseover when HTML & CSS are in the same editor page

痴心易碎 提交于 2020-12-26 08:43:16

问题


I am working on a HTLM editor who combine HTML & CSS in the same page. I want that the users have a zoom when mouseover on a picture in front page

<h4><img style="border: 1px solid black; align: right;" title="" src="sys_attachment.do?sys_id=00ee33cbdb1b9c507261e03cd396190b" alt="" width="204" align="right" border="1" hspace="" vspace="" /></h4>
<h4><strong>4. Entrez votre mot de passe.</strong></h4>
<ul style="list-style-type: disc; list-style-position: inside;">
    <li>Puis, cliquez sur "Suivant".</li>
</ul>

I searched for solution but the solution is always when HTML and CSS are separated If someone has any advice or solution, please help me !

Sorry for my english, i am still learning !


回答1:


Here a full example working with css :hover. No need JS.

You need to set the style element into your head element out of body element

<html>
  <head>
    <style>
    .zoom {
      transition: transform .2s; /* Animation */
    }

    .zoom:hover {
      transform: scale(1.5); /* (150% zoom - Note: if the zoom is too large, it will go outside of the viewport) */
      position:absolute;
      right:0;
    }
    </style>
  </head>
  <body>
    <p>&nbsp;</p>
    <hr />
    <h4 class="zoom"><img style="border: 1px solid black; align: right;" title="" src="https://cdn.pixabay.com/photo/2020/09/09/13/03/bike-riding-5557589_1280.png" alt="" width="204" align="right" border="1" hspace="" vspace="" /></h4>
    <h4><strong>4. Entrez votre mot de passe.</strong></h4>
    <ul style="list-style-type: disc; list-style-position: inside;">
    <li>Puis, cliquez sur "Suivant".</li>
    </ul>
    <p>&nbsp;</p>
  </body>
</html>

Here is a solution with JS Adapt from answer here : Javascript: Zoom in on mouseover WITHOUT Jquery or plugins

<html>
  <head>
    <style>
    </style>
  </head>
  
  <body>
    <p>&nbsp;</p>
      <hr />
      <h4>
        <img id="imgZoom" style="border: 1px solid black; align: right;" width="200px" height="200px" align="right" onmousemove="zoomIn(event)" onmouseout="zoomOut()" src="https://cdn.pixabay.com/photo/2020/09/09/13/03/bike-riding-5557589_1280.png">
        <div style="border: 1px solid black;
            width: 200px;
            height: 200px;
            display: none;
            background-image: url('https://cdn.pixabay.com/photo/2020/09/09/13/03/bike-riding-5557589_1280.png');
            background-repeat: no-repeat;"
            id="overlay"
            onmousemove="zoomIn(event)"></div>
        </h4>
      <h4><strong>4. Entrez votre mot de passe.</strong></h4>
      <ul style="list-style-type: disc; list-style-position: inside;">
      <li>Puis, cliquez sur "Suivant".</li>
      </ul>
    <p>&nbsp;</p>
    
    
    <script>
      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";
      }
    </script>
  </body>
</html>

Last example with style directly in body: It is accepted normaly based https://www.w3.org/Submission/1996/1/WD-jsss-960822

<html>

  <body>
    <style>
      .zoom {
        transition: transform .2s; /* Animation */
      }

      .zoom:hover {
        transform: scale(1.5); /* (150% zoom - Note: if the zoom is too large, it will go outside of the viewport) */
        position:absolute;
        right:0;
      }
      </style>
    <p>&nbsp;</p>
    <hr />
    <h4 class="zoom"><img style="border: 1px solid black; align: right;" title="" src="https://cdn.pixabay.com/photo/2020/09/09/13/03/bike-riding-5557589_1280.png" alt="" width="204" align="right" border="1" hspace="" vspace="" /></h4>
    <h4><strong>4. Entrez votre mot de passe.</strong></h4>
    <ul style="list-style-type: disc; list-style-position: inside;">
    <li>Puis, cliquez sur "Suivant".</li>
    </ul>
    <p>&nbsp;</p>
  </body>
</html>


来源:https://stackoverflow.com/questions/64049671/how-to-do-zoom-on-an-image-while-a-mouseover-when-html-css-are-in-the-same-edi

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!