中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js如何自制圖片放大鏡功能

發布時間:2021-07-09 14:07:22 來源:億速云 閱讀:149 作者:小新 欄目:web開發

這篇文章給大家分享的是有關js如何自制圖片放大鏡功能的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

具體內容如下

注釋:
small img size:600x400
big img size:1200x800

原理:
1、大圖是小圖的 2倍整
2、大圖以小圖片中心點為中心
      a.transform : translate(-50%,-50%)
      b.(rate-0.5)*50%
      c.clip : rect(t,r,b,l) 以小圖邊界為邊界
3、rect必須有absolute
4、獲取鼠標在圖片中的位置
     a.獲取鼠標位置 XY
     b.獲取圖片位置、寬度、高度
             i.得到鼠標在圖片的百分比位置
             ii.將百分比位置應用于大圖 left,top 

問題:
居中理解太差:
          absolute ,left ,top,right,bottom,margin
放大縮小問題:
           起初: transform: scale() 縮放
           利用 transition 過渡
                 結果,采用這種方法會使得鼠標移動時很卡頓
                       可能原因:每次hover 都會觸發 transition事件
           解決方法:采用了 Animate 動畫來實現縮放 

細節:
以 onmouse 事件 e 動態獲得 e.pageX 和 e.pageY
以 $().offset().top /left 獲取圖片位置
以 $().width() /height() 獲取圖片寬高
      在錯誤的操作中也忘了獲取 class 的方法
           $().attr("class")
           $().prop("class")
                    event.traget.className 

如果要實現 hover出現 透明的塊狀就在外部 opacity:0.5; 設置z-index就可以了。

<html>
 <head>
  <meta charset="UTF-8">
  <title>WEBGOD</title>
  <link rel="stylesheet" type="text/css" href="css/bootstrap.min.css"/>
  <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
  <script src="js/bootstrap.min.js" type="text/javascript" charset="utf-8"></script>
  <style type="text/css">
   #warpper{
    margin: 0 auto;
    padding: 0;
    position: relative;
    z-index: 1;
    width: 600px;
    height: 400px;
   }
   .small{
    text-align: center;
   }
   .big{
    display: none;
    clip: rect(200px,900px,600px,300px);
    position: absolute;
    width: 1200px;
    height: 800px;
    top: 50%;
    left:50%;
    transform: translate(-50%,-50%);
   }
   .big img{
    position: absolute;
    width: 600px;
    height: auto;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
   }
  </style>
 </head>
 <body>
   
  <div id="warpper">
   <div class="small">
    <img src="img/small_19.jpg"/>
   </div>
   <div class="big">
    <img src="img/img_19.jpg"/>
   </div>
  </div>
  <script type="text/javascript">
   $(function(){
    var x,y,left,top,width,height,imgWidth,imgHeight,rateX,rateY;
    $("#warpper").hover(function(){
     $(".big").css("display","block");
     $(".big img").animate({"width":"1200px"},500);
    },function(){
     $(".big img").animate({"width":"600px"},1);
     $(".big").css("display","none");
    })
    $("#warpper").on("mousemove",function(e){
     x = e.pageX;
     y = e.pageY;
     top = $(".small img").offset().top;
     left = $(".small img").offset().left;
     width = $(".small img").width();
     height = $(".small img").height();
     //
     imgWidth = $(".big img").width();
     imgHeight = $(".big img").height();
     rateX = (left+width-x)/width;
     rateY = (top+height-y)/height;
     if(rateX>0&&rateY>0&&rateX<=1&&rateY<=1){
      $(".big img").css("left",(rateX-0.5)*50+"%");
      $(".big img").css("top",(rateY-0.5)*50+"%");
     }
    })
   })
  </script>
 </body>
</html>

感謝各位的閱讀!關于“js如何自制圖片放大鏡功能”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

宝清县| 贵阳市| 泸定县| 特克斯县| 静宁县| 蕉岭县| 通道| 罗平县| 闽清县| 黄骅市| 台南县| 郎溪县| 丹凤县| 广宁县| 敦煌市| 安泽县| 宜城市| 五常市| 雷波县| 东乡| 威宁| 灯塔市| 佳木斯市| 大冶市| 吴堡县| 靖边县| 澎湖县| 太仆寺旗| 全南县| 虎林市| 兴国县| 永安市| 霸州市| 油尖旺区| 边坝县| 竹山县| 沧源| 九江县| 正宁县| 鲁山县| 天气|