jquery中怎么實(shí)現(xiàn)放大鏡效果

這篇文章給大家介紹jquery中怎么實(shí)現(xiàn)放大鏡效果,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

創(chuàng)新互聯(lián)公司于2013年開(kāi)始,先為貢覺(jué)等服務(wù)建站,貢覺(jué)等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為貢覺(jué)企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。

html部分:

這里需要使用2長(zhǎng)一定比例的圖片,在頁(yè)面中按比例設(shè)置2個(gè)div中來(lái)存放這2長(zhǎng)圖片,并在小圖片的div中按照一定的比例設(shè)一個(gè)用來(lái)放大的區(qū)域

<div class="img">
    <div class="simg"><!--小圖片-->
        <img src="../作業(yè)/images/small.jpg"/>
        <div id="move"></div><!--放大區(qū)域-->
    </div>
    <div class="bimg"><!--大圖片-->
        <img src="../作業(yè)/images/big.jpg" />
    </div>
</div>

CSS部分:

設(shè)置小圖片、大圖片、放大區(qū)域排版好后,將放大區(qū)域和大圖片隱藏display: none;,因?yàn)槲覀兒竺嫘枰髽?biāo)移動(dòng)到小圖片上是將放大區(qū)域和大圖片中對(duì)應(yīng)的部分顯示出來(lái),其中大圖片只取對(duì)應(yīng)的位置,超出的部分隱藏overflow: hidden;

<style type="text/css">
    .img{width: 350px;height: 350px;border: 1px solid                #ccc;margin: 100px;position: relative;cursor:move;}
    .bimg{position: relative;top: -400px;left: 500px;
         border: 1px solid #ccc;width: 400px;height: 400px;
         overflow: hidden;display: none;}
    #move{position: absolute;width: 100px;height: 100px;
        background-color: rgba(8,152,202,0.2);top: 0px;
        left: 0px;display: none;}
    .bimg>img{position: absolute;left: 0px;top: 0px;}
</style>

JS部分:

首先:需要通過(guò)鼠標(biāo)的hover()事件,實(shí)現(xiàn)鼠標(biāo)移動(dòng)到小圖片上時(shí),放大區(qū)域和大圖片顯示display:block ;,鼠標(biāo)移除小圖片時(shí),放大區(qū)域和大圖片再次隱藏

其次,需要獲取鼠標(biāo)在小圖片上的位置和放大區(qū)域的位置,來(lái)實(shí)現(xiàn)可以跟隨鼠標(biāo)在小圖片上移動(dòng)來(lái)選擇放大的位置mousemove(),要做到這個(gè)效果需要:

1.通過(guò)事件觸發(fā)對(duì)象event獲取鼠標(biāo)位置

event.pageX;  event.pageY;

2.獲取放大區(qū)域的位置

offset().left; offset().top

3.計(jì)算出需要移動(dòng)的距離

需要移動(dòng)的距離 = 鼠標(biāo)在頁(yè)面中的X坐標(biāo) - 小圖片距離頁(yè)面左邊的距離-放大區(qū)域?qū)挾鹊囊话?/p>

需要移動(dòng)的距離 = 鼠標(biāo)在頁(yè)面中的Y坐標(biāo) - 小圖片距離頁(yè)面頂部的距離-放大區(qū)域高度的一半

jquery中怎么實(shí)現(xiàn)放大鏡效果

4.同過(guò)jquery的css()函數(shù)實(shí)現(xiàn)移動(dòng)

最后,實(shí)現(xiàn)大圖片對(duì)應(yīng)的移動(dòng),這里要注意,大圖片的一定是與放大區(qū)域移動(dòng)的方向相反的

//為小圖片添加hover事件 鼠標(biāo)移動(dòng)到小圖片上時(shí),放大區(qū)域和大圖片的div需要顯示出來(lái),反之隱藏
        $(".img").hover(function(){
            $(".bimg").css("display","block");
            $("#move").css("display","block");
        },function(){
            $(".bimg").css("display","none");
            $("#move").css("display","none");
        });
        //需要為小圖片的div添加一個(gè)鼠標(biāo)移動(dòng)時(shí)間
        $(".img").mousemove(function(event){
            //需要獲取鼠標(biāo)移動(dòng)是距離左邊和頂端的距離
            var x = event.pageX;
            var y = event.pageY;
            //需要計(jì)算放大區(qū)域的需要移動(dòng)到的位置
            var nx = x - $(".img").offset().left-$("#move").width()/2;
            var ny = y - $(".img").offset().top-$("#move").height()/2;
            //判斷移動(dòng)后是否已經(jīng)超出的范圍
            if(nx < 0){ //左邊超出
                nx = 0;
            }
            if(nx > $(".img").width()-$("#move").width()){//右邊超出
                nx = $(".img").width()-$("#move").width();
            }
            if(ny < 0){ //頂端超出
                ny = 0;
            }
            if(ny > $(".img").height()-$("#move").height()){//底部超出
                ny = $(".img").height()-$("#move").height();
            }
            //設(shè)置放大區(qū)域的移動(dòng)
            $("#move").css({
                left:nx+"px",
                top:ny+"px"
            });
            //設(shè)置大圖片的移動(dòng)   大圖片的移動(dòng)方向與放大區(qū)域正好相反
            $(".bimg>img").css({
                left:-nx*$("#move").width()/$(".simg").width()+"px",
                top:-ny*$("#move").height()/$(".simg").height()+"px"
            });

關(guān)于jquery中怎么實(shí)現(xiàn)放大鏡效果就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

分享文章:jquery中怎么實(shí)現(xiàn)放大鏡效果
轉(zhuǎn)載來(lái)源:http://muchs.cn/article42/pdjohc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器微信公眾號(hào)、全網(wǎng)營(yíng)銷推廣、搜索引擎優(yōu)化、Google手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名