JavaScript仿淘寶放大鏡效果
更新時(shí)間:2021年10月27日 10:04:56 作者:pure_lin7
這篇文章主要為大家詳細(xì)介紹了JavaScript仿淘寶放大鏡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)淘寶放大鏡效果的具體代碼,供大家參考,具體內(nèi)容如下
html代碼
<div class="thumbnail">
<img src="./img/12-1Z930152149 (2).jpg" alt="">
<div class="magnifier"></div>
</div>
<div class="original">
<img src="./img/12-1Z930152149 (2).jpg" alt="">
</div>
<script src="./index.js"></script>
css代碼
*{
margin: 0;
padding: 0;
}
.thumbnail , .original{
width: 400px;
height: 400px;
border: 1px solid red;
position: absolute;
}
.original{
left: 450px;
overflow: hidden;
display: none;
}
.thumbnail>img{
width: 400px;
}
.original>img{
width: 800px;
position: absolute;
}
.magnifier{
cursor: move;
width: 200px;
height: 200px;
background-color:rgba(206, 198, 198, 0.5);
position: absolute;
top: 0;
left: 0;
display: none;
}
js代碼
// thumbnail 縮略圖
// original 原圖
// magnifier 放大鏡
$(".thumbnail").mouseover(function(){
$(".magnifier").show()
$(".original").show()
})
$(".thumbnail").mousemove(function(ev){
// console.log(ev)
// 鼠標(biāo)相對(duì)頁(yè)面 x y 坐標(biāo)
var mx= ev.pageX;
var my =ev.pageY;
var tx = mx - $(".thumbnail").offset().left
var ty = my - $(".thumbnail").offset().top
var l = tx -$(".magnifier").width()/2;
var t = ty -$(".magnifier").height()/2;
var maxX= $(".thumbnail").width() - $(".magnifier").width();
var maxY= $(".thumbnail").height() -$(".magnifier").height()
// 處理邊界
if( l >maxX){
l = maxX
}
if( t >maxY){
t = maxY
}
if(l <0){
l =0
}
if(t<0){
t=0
}
//放大鏡位置
$(".magnifier").css({
left: l +"px",
top : t + "px"
})
//原圖位置
$(".original >img").css({
left:-l*2 +"px",
top:-t*2 +"px"
})
})
// 鼠標(biāo)離開(kāi) 隱藏 放大鏡 ,原圖
$(".thumbnail").mouseout(function(){
$(".magnifier").hide();
$(".original").hide();
})
效果:


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript 32位整型無(wú)符號(hào)操作示例
所有整數(shù)字變量默認(rèn)都是有符號(hào)整數(shù),JavaScript 進(jìn)行位操作時(shí),是采用32位有符號(hào)整型,這意味著其轉(zhuǎn)換的結(jié)果也是32位有符號(hào)整型2013-12-12
javascript 動(dòng)態(tài)創(chuàng)建表格
這篇文章主要介紹了javascript 動(dòng)態(tài)創(chuàng)建表格,需要的朋友可以參考下2015-01-01
前端微信H5公眾號(hào)實(shí)現(xiàn)授權(quán)登錄的方法總結(jié)
這篇文章主要介紹了如何在微信公眾號(hào)中實(shí)現(xiàn)網(wǎng)頁(yè)授權(quán)功能,包括創(chuàng)建微信服務(wù)公眾號(hào)、配置重定向地址、調(diào)試和開(kāi)發(fā)使用等步驟,文中通過(guò)圖文及代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-01-01
js計(jì)算字符串長(zhǎng)度包含的中文是utf8格式
使用js寫(xiě)的計(jì)算字符串長(zhǎng)度且其中中文是utf8格式的,具體的實(shí)現(xiàn)如下,感興趣的朋友可以參考下2013-10-10

