Heim  >  Artikel  >  Web-Frontend  >  Detaillierte Erläuterung des Beispiels der Verwendung von CSS zur Erzielung des Bildlupeneffekts (Bild)

Detaillierte Erläuterung des Beispiels der Verwendung von CSS zur Erzielung des Bildlupeneffekts (Bild)

PHPz
PHPzOriginal
2017-04-23 09:28:206887Durchsuche

In diesem Artikel wird erläutert, wie Sie mithilfe von CSS das Bild Lupeneffekt ? Das Folgende ist eine detaillierte Erklärung des CSS-Beispiels des Bildlupeneffekts

Der Effekt ist wie im Bild gezeigt (im Beispiel habe ich heimlich ein Bild davon verlinkt). Tmall, ich hoffe, es ist in Ordnung-.-):

Detaillierte Erläuterung des Beispiels der Verwendung von CSS zur Erzielung des Bildlupeneffekts (Bild)

Der Implementierungsprozess ist einfach, aber wir starten die Analyse trotzdem über CSS. Der Prozess ist wie folgt (das Bild ist Quadrat als Beispiel):

css:

/* 图片容器 */
    .imgBox{
      width: 200px; /* 各位大老爷们看着办 */
      height: 200px; /* 各位大老爷们看着办 */
      position: relative; /* 必需 */
    }
 
    /* 图片标签 */
    .mainImg{
      width: 100%; /* 各位大老爷们看着办,尽量100%好看些[斜眼笑] */
      height: 100%; /* 各位大老爷们看着办,尽量100%好看些[斜眼笑] */
    }
 
    /* 遮罩层-既放大区域 */
    .glass{
      position: absolute; /* 必需 */
      width: 50px; /* 遮罩层宽度 此处是放大4倍,所以为200/4=50 */
      height: 50px; /* 遮罩层高度 此处是放大4倍,所以为200/4=50  */
      top: -9999px; /* 绝对位置,先放远些 */
      left: -9999px; /* 绝对位置,先放远些 */
      cursor: move; /* 鼠标样式,好看些 */
      background: rgba(0,0,180,0.5); /* 遮罩层样式,好看些 */
    }
 
    /* 大图所在的容器 */
    .imgMax{
      position: absolute;  /* 必需 */
      overflow: hidden; /* 必需,盖掉超出的大图[斜眼笑] */
      left: 210px; /* 必需,此处为距原图左边10像素 */
      top: 0; /* 必需,此处为距上边0像素 */
      width: 200px; /* 放大图片容器的宽度 此处此处是放大4倍,为200,保持和原图容器一般大,若此处为400,则是放大2*4倍,那么相应的放大图片应该是200*4*2=1600 */
      height: 200px; /* 放大图片容器的高度 此处此处是放大4倍,为200,保持和原图容器一般大,若此处为400,则是放大2*4倍,那么相应的放大图片应该是200*4*2=1600 */
      display: none; /* 先隐藏 */
    }
    .maxImg{
      position: absolute; /* 必需 */
      width: 800px; /* 此处是放大4倍,所以为200*4=800  受放大图片所在的容器影响,规则如上 */
      height: 800px; /* 此处是放大4倍,所以为200*4=800  受放大图片所在的容器影响,规则如上 */
    }

Was Sie im obigen CSS beachten müssen, sind mehrere Positionen und Skalierungsverhältnisse die Anpassungen.

Nachdem wir den Stil geschrieben haben, schauen wir uns das Layout an:

html:

<!-- 图片容器 -->
    <pclass="J_imgBox imgBox">
      <!-- 需要放大的图片-原始图 -->
      <imgclass="J_mainImg mainImg" src="http://img.alicdn.com/bao/uploaded/i7/TB1Xpe_NXXXXXXRXFXXGTq09XXX_035318.jpg_430x430q90.jpg"/>
      <!-- 遮罩-既放大的区域 -->
      <pclass="J_glass glass"></p>
      <!-- 大图的容器 -->
      <pclass="J_imgMax imgMax">
        <!-- 大图 -->
        <imgclass="J_maxImg maxImg"/>
      </p>
    </p>

Das nächste ist das Wichtigste js-Code, mit Kommentaren wie immer:

js:

(function(){
    /* 放大镜函数
    ** @imgContainer  需要实现放大镜效果的图片容器  此处是 class 为 J_imgBox 的 p
    */
    function imgZoom(imgContainer){
 
      // 取大图url,不知道淘宝图片规则如何,反正看了详情页的大图和小图url对比,随便写了个替换
      var imgUrl = imgContainer.querySelector('.J_mainImg').src.replace(/.(jpg|jpeg|png|gif)(_)(d+)(x)(d+)(q90)?/g,'');
 
      // 取大图标签的节点
      var maxImg = imgContainer.querySelector('.J_maxImg');
 
      // 给该节点的src属性赋值为大图的url
      maxImg.src = imgUrl;
 
      // 取大图所在的容器
      var maxImgContainer = imgContainer.querySelector('.J_imgMax');
 
      // 取遮罩块
      var glassBlock = imgContainer.querySelector('.J_glass');
 
      // 取消放大镜效果
      var hideMaxImg = function(){
        glassBlock.style.top = '-9999px';
        glassBlock.style.left = '-9999px';
        maxImgContainer.style.display = 'none';
      }
 
      // 鼠标移出图片区域,取消放大镜效果
      imgContainer.onmouseout = function(event){
        event.stopPropagation();
        hideMaxImg();
      };
 
      // 鼠标在图片区域内移动事件
      imgContainer.onmousemove = function(event) {
        event.stopPropagation();
 
        // 取图片容器的大小及其相对于视口的位置,需要实时取,所以放在move事件里
        var clientRect = event.currentTarget.getBoundingClientRect();
 
        // 获取距鼠标距的上和左的坐标
        var leftX = event.clientX - clientRect.left;
        var leftY = event.clientY - clientRect.top;
 
        // 动态设置遮罩块的left和top位置  这里需要减去遮罩层的一半,因为鼠标位于遮罩块中心点
        var pointerLeft = leftX - 25;
        var pointerTop = leftY - 25;
 
        // 如果鼠标坐标移动超出原始图片区域边缘 则取消放大镜效果  因为这里存在快速移动鼠标到大图区域时,鼠标仍处在外层的图片区域内,并不会触发mouseout事件(虽然中间隔了小小的间距,但是快速移动仍能产生这个bug,如代码下面的图所示)
        if((pointerLeft+25) > clientRect.width || pointerLeft  clientRect.height || pointerTop ){
          hideMaxImg();
          return !1;
        };
 
        // 遮罩块在最左边的时候,鼠标仍在图片区域内,可在遮罩块左边缘至中心线区域内移动,且这时遮罩块为距左0像素
        if(pointerLeft ){
          pointerLeft = 0;
        };
 
        // 同上 右边限制
        if(pointerLeft > clientRect.width - 50){
          pointerLeft = clientRect.width - 50;
        };
 
        // 同上 顶部限制
        if(pointerTop ){
          pointerTop = 0;
        };
 
        // 同上 底部限制
        if(pointerTop > clientRect.height - 50){
          pointerTop = clientRect.height - 50;
        };
 
        // 设置遮罩块的位置
        glassBlock.style.left = pointerLeft;
        glassBlock.style.top = pointerTop;
 
        // 取遮罩快距离左边的位置和图片区域的宽高比,用于计算大图偏移距离,展示遮罩块所对应的图片区域
        var percentLeft = pointerLeft/clientRect.width;
        var percentHeight = pointerTop/clientRect.height;
 
        // 设置大图偏移距离 因为其父元素存在 overflow:hidden 所以只会展示对应区块
        maxImg.style.left = -(percentLeft*maxImg.clientWidth)+'px';
        maxImg.style.top = -(percentHeight*maxImg.clientHeight)+'px';
      };
    }
 
    var elem = document.querySelectorAll('.J_imgBox');
 
    elem.forEach(function(item,idx){
      imgZoom(item)
    })
  })()

Bugfix-Bild:

Detaillierte Erläuterung des Beispiels der Verwendung von CSS zur Erzielung des Bildlupeneffekts (Bild)

Haben Sie nach dem Lesen das Gefühl, dass es nicht zu einfach ist? Schauen wir uns als Nächstes die praktischeren Wissenspunkte an, die in der täglichen Entwicklung aus dem obigen Code extrahiert werden können:

Element.getBoundingClientRect()

Element.getBoundingClientRect()-Methode gibt die Größe des Elements und seine Position relativ zum Ansichtsfenster zurück

Beispiel:

<bodystyle="width:1400;height:1000">
      <pid="testp" style="width:10px;height:20px;background:#f00"></p>
      <script>
        (function(){
          var elem = document.getElementById('testp');
          document.body.addEventListener('click',function(){
              console.log(elem.getBoundingClientRect())
          },false)
        })()
      </script>
    </body>

Der Effekt ist wie im Bild gezeigt:

Detaillierte Erläuterung des Beispiels der Verwendung von CSS zur Erzielung des Bildlupeneffekts (Bild)

Auf dem Effektbild ist nicht schwer zu erkennen, dass gedruckt wird, wenn ich die

Ansicht verschiebe und dann auf den Körper klicke Das -Objekt kann die Größe des Elements und seine Position relativ zum Ansichtsfenster korrekt zurückgeben

Diese Methode kann auch verwendet werden, um das entsprechende Ereignis auszulösen, wenn ein Element nach unten/oben gescrollt wird , was sehr praktisch ist.

Event

1.event.target und event.currentTarget

target: Zeigen Sie auf das Element, das das Ereignis ausgelöst hat

currentTarget: Zeigen Sie auf das gebundene Ereignishandle. Das Element

ist nur dann dasselbe, wenn der gebundene

Ereignishandler und das Programm, das den Ereignishandler auslöst, dasselbe Objekt

sind Beispielcode:

html:

  <pid="ap">
      123
      <pid="bp">456</p>
    </p>

js:

  document.getElementById('ap').addEventListener('click',function(e){
    if(e.target === e.currentTarget) {
      console.log('target === currentTarget')
    }else{
      console.log('target !== currentTarget')
    }
    console.log('target',e.target)
    console.log('currentTarget',e.currentTarget)
  },false)

Rendering:

Detaillierte Erläuterung des Beispiels der Verwendung von CSS zur Erzielung des Bildlupeneffekts (Bild)

Aus dem Rendering können wir erkennen, dass beim Klicken auf 456 das Ziel auf den BP zeigt, in dem sich 456 befindet, und das aktuelle Ziel auf ap zeigt, da das Ereignis an ap gebunden ist, aber Der Auslöser befindet sich auf bp und der bp befindet sich im ap. Wenn auf 123 geklickt wird, stimmt das Ziel mit dem aktuellen Ziel überein und sowohl die Bindung als auch die Auslösung erfolgen auf dem ap.

2.event.preventDefault() & event.stopPropagation()

preventDefault: Wenn das Ereignis stornierbar ist, brechen Sie das Ereignis ab, ohne die weitere Ausbreitung des Ereignisses zu stoppen

stopPropagation : Verhindern Sie die weitere Ausbreitung des aktuellen Ereignisses in der Erfassungs- und Bubbling-Phase

3.event.stopPropagation() & event.stopImmediatePropagation()

stopPropagation: Verhindern Sie das aktuelle Ereignis in der Erfassungs- und Bubbling-Phase Phasen Weitere Ausbreitung von

stopImmediatePropagation: verhindert, dass andere Ereignis-Listener dasselbe Ereignis auf dem Element aufrufen, und verhindert Sprudeln

Beispiel für den Unterschied zwischen den beiden:

html:

  <pid="ap">
      123
      <pid="bp">456</p>
    </p>

js:

  document.getElementById('ap').addEventListener('click',function(){
    console.log('click ap')
  },false)
  document.getElementById('bp').addEventListener('click',function(e){
    e.stopImmediatePropagation();
    console.log('click bp')
  },false)
  document.getElementById('bp').addEventListener('click',function(){
    console.log('click me too')
  },false)

Das Ausführungsergebnis des obigen Codes ist:

clickbp

Kommentieren Sie das Ergebnis von e.stopImmediatePropagation(); Ich kann mit den Details beginnen. -~

clickbp
clickmetoo
clickap

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des Beispiels der Verwendung von CSS zur Erzielung des Bildlupeneffekts (Bild). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn