欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實(shí)現(xiàn)圖片放大鏡插件詳解

 更新時(shí)間:2017年11月06日 08:37:58   作者:一個(gè)檸檬  
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)圖片放大鏡插件的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

前  言

  我們大家經(jīng)常逛各種電商類的網(wǎng)站,商品的細(xì)節(jié)就需要用到放大鏡,這個(gè)大家一定不陌生,今天我們就做一個(gè)圖片放大鏡的插件,來看看圖片是如何被放大的……

先看一下我們要是實(shí)現(xiàn)的最終效果是怎么樣的    

看完效果,大家有思路了嗎,沒有的話,我們一起來看一下是如何實(shí)現(xiàn)的~

1實(shí)現(xiàn)思路

① 要實(shí)現(xiàn)指上后放大的效果,需要做三個(gè)div,一個(gè)用來放原圖,另一個(gè)用來放放大效果的div,最后一個(gè)是鼠標(biāo)指上后需要放大部分的div(這個(gè)div我們用p標(biāo)簽來代替)。

② 確定放大比例,最重要的一點(diǎn),鼠標(biāo)指上的div與放大效果的div,和原圖與放大圖的比例要相等。

③ 將鼠標(biāo)指上后的放大效果顯示出來。

2具體實(shí)現(xiàn)步驟

 首先,我們先來建三個(gè)div。

<div id="wrapper"> 
     <!--小圖-->
    <div id="img_min"> 
       <!--圖片-->
       <img src="img/11.png" alt="min"> 
       <!--跟隨鼠標(biāo)的白塊-->
       <p id="mousebg"></p> 
     </div> 
   <!--大圖-->
     <div id="img_max">
       <img id="img2_img" src="img/11.png" alt="max">
     </div> 
   </div> 

我們HTML代碼部分已經(jīng)全部完成,接下來,我們用JS來實(shí)現(xiàn)功能:

給原圖添加三個(gè)事件,分別是,鼠標(biāo)進(jìn)入,鼠標(biāo)移動(dòng),鼠標(biāo)移出。

當(dāng)鼠標(biāo)移入原圖時(shí),鼠標(biāo)指上時(shí)的div和放大效果的div同時(shí)顯示。

img1.onmouseover = function () { 
       //鼠標(biāo)進(jìn)入 
       img2.style.display = 'block'; 
       mousebg.style.display = 'block'; 
      
     }     

鼠標(biāo)移出事件:

 img1.onmouseout = function () { 
       //鼠標(biāo)離開 
       img2.style.display = 'none'; 
       mousebg.style.display = 'none'; 
     } 

重點(diǎn)是當(dāng)鼠標(biāo)移動(dòng)時(shí),根據(jù)p標(biāo)簽與原圖的位置,來顯示大圖需要放大的部分。

var _event = event||window.event;//兼容性處理 
var mouseX = _event.clientX - img1.offsetLeft; 
 //計(jì)算鼠標(biāo)相對(duì)與小圖的位置 
var mouseY = _event.clientY - img1.offsetTop; 

在做位置分析時(shí),需要考慮四種臨界情況:

就是當(dāng)鼠標(biāo)從圖片的上、下、左、右剛剛進(jìn)入時(shí),并且這個(gè)距離小于鼠標(biāo)指上的div寬度的二分之一時(shí),放大效果的div顯示出來,并不移動(dòng)。

//特殊情況處理,分別靠近四條邊的時(shí)候 
 if(mouseX<mousebg.offsetWidth/2){ 
  mouseX = mousebg.offsetWidth/2; 
   } 
 if(mouseX>img1.offsetWidth-mousebg.offsetWidth/2){ 
  mouseX = img1.offsetWidth-mousebg.offsetWidth/2; 
   } 
 if(mouseY<mousebg.offsetHeight/2){ 
  mouseY = mousebg.offsetHeight/2; 
 } 
 if(mouseY>img1.offsetHeight-mousebg.offsetHeight/2){ 
  mouseY = img1.offsetHeight-mousebg.offsetHeight/2; 
 } 

最后,計(jì)算大圖的顯示范圍:

 //計(jì)算大圖的顯示范圍 
 img2_img.style.left = -mul*mouseX+img2.offsetWidth/2+"px"; 
 img2_img.style.top = -mul*mouseY+img2.offsetHeight/2+"px"; 
 //使鼠標(biāo)在白塊的中間 
mousebg.style.left = mouseX-mousebg.offsetWidth/2+"px"; 
mousebg.style.top = mouseY-mousebg.offsetHeight/2+"px"; 

這樣,我們用JS實(shí)現(xiàn)圖片放大鏡的插件就全部完成了。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript使用DeviceOne開發(fā)實(shí)戰(zhàn)(三)仿微信應(yīng)用

    JavaScript使用DeviceOne開發(fā)實(shí)戰(zhàn)(三)仿微信應(yīng)用

    這篇文章主要介紹了JavaScript使用DeviceOne開發(fā)實(shí)戰(zhàn)(三)仿微信應(yīng)用的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • Bootstrap4一次重大更新 幾乎涉及每行代碼

    Bootstrap4一次重大更新 幾乎涉及每行代碼

    Bootstrap 4是一次重大更新,幾乎涉及每行代碼,這篇文章為大家分享了Bootstrap 4.0重大更新及亮點(diǎn)詳細(xì)解讀,感興趣的小伙伴們可以參考一下
    2016-05-05
  • javascript解析json格式的數(shù)據(jù)方法詳解

    javascript解析json格式的數(shù)據(jù)方法詳解

    這篇文章主要介紹了javascript解析json格式的數(shù)據(jù)方法詳解,文章通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • BootStrap入門教程(二)之固定的內(nèi)置樣式

    BootStrap入門教程(二)之固定的內(nèi)置樣式

    這篇文章主要介紹了BootStrap入門教程(二)之固定的內(nèi)置樣式的相關(guān)資料,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧
    2016-09-09
  • 淺談js之字面量、對(duì)象字面量的訪問、關(guān)鍵字in的用法

    淺談js之字面量、對(duì)象字面量的訪問、關(guān)鍵字in的用法

    下面小編就為大家?guī)硪黄獪\談js之字面量、對(duì)象字面量的訪問、關(guān)鍵字in的用法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-11-11
  • 利用uniapp開發(fā)APP時(shí)的調(diào)試/安卓打包等詳解

    利用uniapp開發(fā)APP時(shí)的調(diào)試/安卓打包等詳解

    uni-app??是一個(gè)使用??Vue.js開發(fā)所有前端應(yīng)用的框架,開發(fā)者編寫一套代碼,下面這篇文章主要給大家介紹了關(guān)于利用uniapp開發(fā)APP時(shí)的調(diào)試/安卓打包等的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • JS異步宏隊(duì)列微隊(duì)列原理詳解

    JS異步宏隊(duì)列微隊(duì)列原理詳解

    這篇文章主要介紹了JS異步宏隊(duì)列微隊(duì)列原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • JavaScript Canvas編寫炫彩的網(wǎng)頁時(shí)鐘

    JavaScript Canvas編寫炫彩的網(wǎng)頁時(shí)鐘

    這篇文章主要為大家詳細(xì)介紹了JavaScript Canvas編寫炫彩的網(wǎng)頁時(shí)鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • javascript實(shí)現(xiàn)攝像頭拍照預(yù)覽

    javascript實(shí)現(xiàn)攝像頭拍照預(yù)覽

    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)攝像頭拍照預(yù)覽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • js遍歷對(duì)象key和value實(shí)戰(zhàn)舉例

    js遍歷對(duì)象key和value實(shí)戰(zhàn)舉例

    這篇文章主要給大家介紹了關(guān)于js遍歷對(duì)象key和value的相關(guān)資料,隨著JavaScript在web應(yīng)用程序中的廣泛使用,遍歷對(duì)象的key和value成為了編寫復(fù)雜代碼所必需的技能,需要的朋友可以參考下
    2023-07-07

最新評(píng)論