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

js實(shí)現(xiàn)簡單的放大鏡效果

 更新時(shí)間:2021年09月07日 11:23:19   作者:LZC_yEllOwBooK  
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)簡單的放大鏡效果,可隨意更改,放大區(qū)域的大小、比例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了js實(shí)現(xiàn)簡單放大鏡效果的具體代碼,供大家參考,具體內(nèi)容如下

效果

效果,鼠標(biāo)在原圖片移動(dòng),黃色小盒子跟隨鼠標(biāo)移動(dòng),黃色小盒子蓋住的部分,在顯示區(qū)顯示

效果圖如下:

核心思路

1.鼠標(biāo)放置在圖片上,顯示區(qū)出現(xiàn),鼠標(biāo)離開小盒子,顯示區(qū)消失

2.鼠標(biāo)在圖片上移動(dòng)時(shí),小盒子跟隨鼠標(biāo)移動(dòng),且鼠標(biāo)在黃色小盒子中間位置

3.小盒子給判斷,讓其不能超出圖片區(qū)域

4.小盒在圖片上移動(dòng)多少,顯示區(qū)域要移動(dòng)同比例的距離

5.當(dāng)顯示區(qū)大小發(fā)生改變,或顯示區(qū)內(nèi)容增大變小,原來圖片上的黃色小盒子隨之改變

操作

1.先把需要用到元素獲取過來

 // 獲取頁面上我們需要的元素
        var box1=document.querySelector('.box1')
        var yellow=document.querySelector('.yellow')
        var box2=document.querySelector('#rightbox')
        var screen=rightbox.children[0]

2.鼠標(biāo)放置到圖片,顯示區(qū)域出現(xiàn),離開則消失

// 鼠標(biāo)進(jìn)入和離開圖片
        box1.onmouseenter=function(){
            box2.style.display='block'
        }
        box1.onmouseleave=function(){
            box2.style.display='none'
        }

利用鼠標(biāo)的進(jìn)入和離開事件就可以做到,分別設(shè)置出現(xiàn)和不出現(xiàn)就好了

3.鼠標(biāo)移動(dòng),小盒子跟隨移動(dòng),且鼠標(biāo)在黃色小盒子中間

box1.onmousemove=function(e){
          // 算出小盒子在圖片時(shí),自身的中心點(diǎn)
           var x=e.pageX-box1.offsetLeft-yellow.offsetWidth/2
           var y=e.pageY-box1.offsetTop-yellow.offsetHeight/2
         //    給黃色小盒子賦值,讓黃色小盒子跟隨鼠標(biāo)移動(dòng)
         yellow.style.left=x+'px'
           yellow.style.top=y+'px'
        }

1.使用事件,鼠標(biāo)在圖片上每一棟一下就觸發(fā),做到隨時(shí)刷新

2.計(jì)算出小盒子在圖片時(shí),自身的中心點(diǎn)

公式:(用鼠標(biāo)在頁面的位置,減去,圖片的偏移距離,減去自身的一半)

這里減去一半是保證鼠標(biāo)在黃色盒子位置始終保持居中

4.小盒子給判斷條件,讓黃色小盒子不能超出圖片區(qū)域

// 鼠標(biāo)在圖片上移動(dòng)觸發(fā)事件
        box1.onmousemove=function(e){
            // 算出小盒子在圖片的中心點(diǎn)
           var x=e.pageX-box1.offsetLeft-yellow.offsetWidth/2
           var y=e.pageY-box1.offsetTop-yellow.offsetHeight/2
 
   // --------------------------------------------------------------------------------
 // 新增部分
        //    判斷小盒子是否超出img范圍,使黃色小盒子不能超出img范圍
           if(x<0){
            //    此時(shí)的0不是圖片的左側(cè),而是小盒子在最左邊時(shí),小盒子的中心點(diǎn)
               x=0
           }else if(x>box1.offsetWidth-yellow.offsetWidth){
            //    小盒子的X軸中心點(diǎn)大于圖片盒子的寬度減去自身寬度時(shí),說明超出,則始終等于圖片盒子的寬度減去自身寬度
            x=box1.offsetWidth-yellow.offsetWidth
           }
 
        //    同上
           if(y<0){
               y=0
           }else if(y>box1.offsetHeight-yellow.offsetHeight){
            y=box1.offsetHeight-yellow.offsetHeight
           }
 
   // ---------------------------------------------------------------------------------
        //    給黃色小盒子賦值,讓黃色小盒子跟隨鼠標(biāo)移動(dòng)
           yellow.style.left=x+'px'
           yellow.style.top=y+'px'

1.判斷小盒子的左邊是不是超出圖片部分,給的if(x<0)此時(shí)的0,還是以中心點(diǎn)來計(jì)算的

2.判斷右邊 x>box1.offsetWidth-yellow.offsetWidth

(是否大于   圖片區(qū)域?qū)挾?nbsp; 減去 小盒子寬度)

為什么是小盒子寬度,判定的是小盒子中心點(diǎn),且0的位置是小盒子的中心點(diǎn),已經(jīng)減去過一半的小盒子,所以右邊減去的就是小盒的一半*2

3.上下也一樣,這個(gè)時(shí)候黃色小盒子就不會(huì)超出圖片區(qū)域了

5.小盒在圖片上移動(dòng)多少,顯示區(qū)域要移動(dòng)同比例的距離

// 通過計(jì)算,得出小盒子在圖片移動(dòng)多少,顯示區(qū)就移動(dòng)多少的比例
 srceen.style.left=-x/box1.offsetWidth*srceen.offsetWidth+'px'
 srceen.style.top=-y/box1.offsetHeight*srceen.offsetHeight+'px'

顯示區(qū)域移動(dòng)的多少,取決于小盒子移動(dòng)多少

小盒子移動(dòng)的值  除以  圖片的寬度   乘以   顯示區(qū)域的寬度

顯示區(qū)域的移動(dòng)值 就可以和小盒子 在圖片的移動(dòng)比例  相同

6.顯示區(qū)大小改變或顯示區(qū)內(nèi)容變化,圖片上黃色盒子隨之改變

 //  計(jì)算黃色小盒子在圖片上的大小
           yellow.style.width=box1.offsetWidth/(srceen.offsetWidth/box2.offsetWidth)+'px'
           yellow.style.height=box1.offsetHeight/(srceen.offsetHeight/box2.offsetHeight)+'px'
        }

計(jì)算方式為:黃色盒子的寬=圖片的寬/(顯示區(qū)域的內(nèi)容寬度/顯示區(qū)域的框的寬度)

高度也是一樣的

因?yàn)?,是鼠?biāo)移動(dòng)觸發(fā),所以實(shí)時(shí)刷新

調(diào)整

.img2{
            width: 3000px;
            height: 3000px;
            position: absolute;
        }
        #rightbox{
            position: absolute;
            top: 0;
            left: 650px;
            width: 900px;
            height: 900px;
            overflow: hidden;
            display: none;
        }

當(dāng)需要調(diào)整框的大小,或放大比例時(shí),改變這兩個(gè)樣式的寬高即可

內(nèi)容,css,js 整體代碼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            padding: 0;
            margin: 0;
        }
        .img1{
            width: 300px;
            height: 300px;
        }
        .img2{
            width: 3000px;
            height: 3000px;
            position: absolute;
        }
        #rightbox{
            position: absolute;
            top: 0;
            left: 650px;
            width: 900px;
            height: 900px;
            overflow: hidden;
            display: none;
        }
        .yellow{
            background-color: yellow;
            opacity: 0.5;
            width: 100px;
            height: 100px;
            position: absolute;
            top: 0;
            left: 0;
        }
        .box1{
            width: 300px;
            height: 300px;
            position: relative;
            margin-left: 300PX;
        }
    </style>
</head>
<body>
    <div class="box1">
        <img src="./images/1.jpg" alt="" class="img1">
        <div class="yellow"></div>
    </div>
    <div id="rightbox">
        <img src="./images/1.jpg" alt="" class="img2">
    </div>
    <script>
        // 獲取頁面上我們需要的元素
        var box1=document.querySelector('.box1')
        var yellow=document.querySelector('.yellow')
        var box2=document.querySelector('#rightbox')
        var srceen=rightbox.children[0]
        // 鼠標(biāo)進(jìn)入和離開圖片
        box1.onmouseenter=function(){
            box2.style.display='block'
        }
        box1.onmouseleave=function(){
            box2.style.display='none'
        }
        // 鼠標(biāo)在圖片上移動(dòng)觸發(fā)事件
        box1.onmousemove=function(e){
            // 算出小盒子在圖片的中心點(diǎn)
           var x=e.pageX-box1.offsetLeft-yellow.offsetWidth/2
           var y=e.pageY-box1.offsetTop-yellow.offsetHeight/2
 
 
        //    判斷小盒子是否超出img范圍,使黃色小盒子不能超出img范圍
           if(x<0){
            //    此時(shí)的0不是圖片的左側(cè),而是小盒子在最左邊時(shí),小盒子的中心點(diǎn)
               x=0
           }else if(x>box1.offsetWidth-yellow.offsetWidth){
            //    小盒子的X軸中心點(diǎn)大于圖片盒子的寬度減去自身寬度時(shí),說明超出,則始終等于圖片盒子的寬度減去自身寬度
            x=box1.offsetWidth-yellow.offsetWidth
           }
 
        //    同上
           if(y<0){
               y=0
           }else if(y>box1.offsetHeight-yellow.offsetHeight){
            y=box1.offsetHeight-yellow.offsetHeight
           }
 
 
        //    給黃色小盒子賦值,讓黃色小盒子跟隨鼠標(biāo)移動(dòng)
           yellow.style.left=x+'px'
           yellow.style.top=y+'px'
 
 
        //    通過計(jì)算,得出小盒子在圖片移動(dòng)多少,顯示區(qū)就移動(dòng)多少的比例
           srceen.style.left=-x/box1.offsetWidth*srceen.offsetWidth+'px'
           srceen.style.top=-y/box1.offsetHeight*srceen.offsetHeight+'px'
 
        //    計(jì)算黃色小盒子在圖片上的大小
           yellow.style.width=box1.offsetWidth/(srceen.offsetWidth/box2.offsetWidth)+'px'
           yellow.style.height=box1.offsetHeight/(srceen.offsetHeight/box2.offsetHeight)+'px'
        }
        
    </script>
</body>
</html>

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

相關(guān)文章

  • 微信小程序之多文件下載的簡單封裝示例

    微信小程序之多文件下載的簡單封裝示例

    本篇文章主要介紹了微信小程序之多文件下載的簡單封裝示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • Driver.js前端引導(dǎo)頁組件的具體使用

    Driver.js前端引導(dǎo)頁組件的具體使用

    Driver.js是一個(gè)引導(dǎo)插件,本文主要介紹了Driver.js前端引導(dǎo)頁組件的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Javascript的常規(guī)數(shù)組和關(guān)聯(lián)數(shù)組對(duì)比小結(jié)

    Javascript的常規(guī)數(shù)組和關(guān)聯(lián)數(shù)組對(duì)比小結(jié)

    關(guān)聯(lián)數(shù)組雖然可以用字符串作下標(biāo),但是這個(gè)下標(biāo)是不支持參數(shù)傳值的,換言之,你需要什么就取什么,聽起來很智能,實(shí)際上你取值仍然需要你手動(dòng)去寫下標(biāo)的
    2012-05-05
  • 前端項(xiàng)目npm?install?安裝依賴報(bào)錯(cuò)的解決方案(三種問題解決方案)

    前端項(xiàng)目npm?install?安裝依賴報(bào)錯(cuò)的解決方案(三種問題解決方案)

    本文給大家介紹前端項(xiàng)目npm?install?安裝依賴報(bào)錯(cuò)的解決方案(三種問題解決方案),給大家總結(jié)了前端項(xiàng)目安裝依賴,遇到過的問題,每一種問題給大家完美解決方案,感興趣的朋友一起看看吧
    2023-12-12
  • js 驗(yàn)證密碼強(qiáng)弱的小例子

    js 驗(yàn)證密碼強(qiáng)弱的小例子

    js 驗(yàn)證密碼強(qiáng)弱的小例子,需要的朋友可以參考一下
    2013-03-03
  • js 獲取(接收)地址欄參數(shù)值的方法

    js 獲取(接收)地址欄參數(shù)值的方法

    當(dāng)?shù)刂窓诤袇?shù),我們可以再目標(biāo)頁面通過window.location.search來獲取我們需要的參數(shù)及其值,接下來為大家介紹下詳細(xì)獲取方法,感興趣的朋友可以參考下哈
    2013-04-04
  • 純js實(shí)現(xiàn)仿QQ郵箱彈出確認(rèn)框

    純js實(shí)現(xiàn)仿QQ郵箱彈出確認(rèn)框

    仿QQ郵箱的彈出層,彈出確認(rèn)框,主要是用火狐的firebug把html和css扣了下來,沒有做封裝,就定義了一個(gè)拖動(dòng)事件. 大家可以封裝自己的彈出窗,嘿嘿!
    2015-04-04
  • 簡單了解Ajax表單序列化的實(shí)現(xiàn)方法

    簡單了解Ajax表單序列化的實(shí)現(xiàn)方法

    這篇文章主要介紹了簡單了解Ajax表單序列化的實(shí)現(xiàn)方法,隨著Ajax的出現(xiàn),表單序列化已經(jīng)成為一種需求,在學(xué)習(xí)原生Ajax時(shí),若用POST方法向后臺(tái)提交數(shù)據(jù)時(shí),就需要將表單序列化,需要的朋友可以參考下
    2019-06-06
  • JS實(shí)現(xiàn)的tab切換選項(xiàng)卡效果示例

    JS實(shí)現(xiàn)的tab切換選項(xiàng)卡效果示例

    這篇文章主要介紹了JS實(shí)現(xiàn)的tab切換選項(xiàng)卡效果,結(jié)合具體實(shí)例形式分析了JS通過鼠標(biāo)事件觸發(fā)自定義函數(shù)控制頁面元素樣式變換實(shí)現(xiàn)tab切換功能的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-02-02
  • js 函數(shù)的副作用分析

    js 函數(shù)的副作用分析

    函數(shù)副作用 指當(dāng)調(diào)用函數(shù)時(shí),除了返回函數(shù)值之外,還對(duì)主調(diào)用函數(shù)產(chǎn)生附加的影響。例如修改全局變量(函數(shù)外的變量)或修改參數(shù)。
    2011-08-08

最新評(píng)論