js實(shí)現(xiàn)圖片局部放大效果詳解
圖片局部放大效果結(jié)合的知識點(diǎn)主要是DOM的操作,以及事件的應(yīng)用,所以首先要對DOM的操作有一定了解,其次能對事件的應(yīng)用有一定的累積。

如上圖,可以看到,這是放大鏡的基本效果,主要分成左右兩個(gè)部分。左邊分成一張大圖,和一個(gè)導(dǎo)航欄,在右邊則是一個(gè)放大鏡放大后的圖片。因此,我在畫頁面的時(shí)候,大體的HTMl結(jié)構(gòu)如下:
<body>
<div class="choose">
<div class="content">
<img src="images/small1.jpg" id = "small">
<div class="shadow"></div>
</div>
<ul id = "listshow">
<li class="selected">
<img src="images/small1.jpg" data-img = "images/big1.jpg" alt="">
</li>
<li>
<img src="images/small2.jpg" data-img = "images/big2.jpg" alt="">
</li>
<li>
<img src="images/small3.jpg" data-img = "images/big3.jpg" alt="">
</li>
<li>
<img src="images/small4.jpg" data-img = "images/big4.jpg" alt="">
</li>
</ul>
</div>
<div class="larger">
<img src="images/big1.jpg" id = "big">
</div>
</body>
在這個(gè)時(shí)候,將靜態(tài)頁面按常規(guī)方式進(jìn)行布局,給予css樣式如下:
<style>
*{
padding: 0;
margin: 0;
list-style: none;
}
.choose{
width: 400px;
height: 600px;
float: left;
margin:50px 0 0 50px;
}
.content{
width: 400px;
height: 400px;
position: relative;
}
.content img {
width: 400px;
height: 400px;
}
#listshow{
width: 400px;
height: 100px;
margin-top: 20px;
}
#listshow li{
width: 98px;
height: 100px;
float: left;
border:1px solid #666;
}
#listshow li img{
width: 98px;
height: 100px;
}
#listshow .selected{
border-color: brown;
}
.larger{
width: 400px;
height: 400px;
position: absolute;
top: 50px;
left: 500px;
float: left;
overflow: hidden;
display: none;
}
#big{
width: 800px;
height: 800px;
position: absolute;
left: 0;
top: 0;
}
.shadow{
width: 200px;
height: 200px;
background-color: rgba(145,200,200,.4);
position: absolute;
left: 0;
top: 0;
z-index: 10;
display: none;
}
</style>
那么這個(gè)時(shí)候,開始寫js樣式,分布書寫的話,第一步要考慮到左邊的選項(xiàng)卡。選項(xiàng)卡我采用直接使用src賦值的方法,將滑過的圖片對應(yīng)的src給大圖,代碼呈現(xiàn):
for(var i = 0;i<showli.length;i++){
var showitem = showli[i];
showitem.onmouseover =showitem.onclick = function(e){
let evt = window.event||e;
for(var j =0;j<showli.length;j++){
showli[j].className = "";
}
var showimg = this.getElementsByTagName("img")[0];
var imgsrc = showimg.src;
small.src = imgsrc;
var bigsrc = showimg.getAttribute("data-img");
big.src = bigsrc;
this.className = "selected";
}
}
這樣就可以成功實(shí)現(xiàn)選項(xiàng)卡功能,比較簡單粗暴的一種方式,當(dāng)然,大家使用selected結(jié)合點(diǎn)擊下標(biāo)和大圖下標(biāo)相等的這一點(diǎn),也一樣可以做出來。
接下來要考慮到,鼠標(biāo)在大圖上移動(dòng)時(shí),遮罩層的移動(dòng)效果。值得一提的時(shí)候,這個(gè)地方其實(shí)存在一個(gè)視覺上的誤區(qū),看起來是在滑動(dòng)遮罩層,其實(shí)是鼠標(biāo)的滑動(dòng),而遮罩層通過獲取鼠標(biāo)的clientX,clientY來確定自己的位置,遮罩層位置獲取代碼:
content.onmousemove = function (e) {
var evt = window.event||e;
larger.style.display = "block";
shadow.style.display = "block";
var clientX = evt.clientX;
var clientY = evt.clientY;
var scrollLeft = document.documentElement.scrollLeft||document.body.scrollLeft;
var scrollTop = document.documentElement.scrollTop||document.body.scrollTop;
var X = clientX+scrollLeft-chooseMarginL-shadowW/2;
var Y = clientY+scrollTop-chooseMarginT-shadowH/2;
if(X<=0){
X = 0;
}
if(X>=maxX){
X = maxX;
}
if(Y<=0){
Y = 0;
}
if(Y>=maxY){
Y = maxY;
}
// 防止遮罩層粘滯,跟隨鼠標(biāo)一起滑出大圖位置
var bigX = X*bigW/contentW;
var bigY = Y*bigH/contentH;
// bigX / bigW = X / contentW,主圖和遮罩層之間存在兩倍關(guān)系,放大圖和原圖之間也有兩倍關(guān)系
shadow.style.left = X+"px";
shadow.style.top = Y+"px";
big.style.left = -bigX+"px";
big.style.top = -bigY+"px";
}
在這里,計(jì)算較多,尤其要注意遮罩層陰影,主圖以及放大圖之間的倍數(shù)關(guān)系。
到這里,基本功能就實(shí)現(xiàn)了,這里面涉及的計(jì)算可以適當(dāng)配圖理解,尤其注意點(diǎn)擊位置的獲取。
以上所述是小編給大家介紹的js實(shí)現(xiàn)圖片局部放大效果詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- javascript實(shí)現(xiàn)商品圖片放大鏡
- js實(shí)現(xiàn)點(diǎn)擊圖片在屏幕中間彈出放大效果
- JavaScript實(shí)現(xiàn)圖片放大鏡效果
- JavaScript實(shí)現(xiàn)多張圖片放大鏡效果示例【不限定圖片尺寸,rem單位】
- JavaScript實(shí)現(xiàn)圖片的放大縮小及拖拽功能示例
- js實(shí)現(xiàn)圖片放大并跟隨鼠標(biāo)移動(dòng)特效
- JS滾輪控制圖片縮放大小和拖動(dòng)的實(shí)例代碼
- JS與CSS3實(shí)現(xiàn)圖片響應(yīng)鼠標(biāo)移動(dòng)放大效果示例
- JS實(shí)現(xiàn)圖片放大鏡插件詳解
- js實(shí)現(xiàn)圖片放大展示效果
- hammer.js實(shí)現(xiàn)圖片手勢放大效果
- JavaScript實(shí)現(xiàn)圖片放大預(yù)覽效果
相關(guān)文章
javascript學(xué)習(xí)筆記(七) js函數(shù)介紹
javascript學(xué)習(xí)筆記之js函數(shù)介紹,需要的朋友可以參考下2012-06-06
貼一個(gè)在Mozilla中常用的Javascript代碼
貼一個(gè)在Mozilla中常用的Javascript代碼...2007-01-01
淺談Javascript常用正則表達(dá)式應(yīng)用
這篇文章主要介紹了Javascript常用正則表達(dá)式應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
淺析JavaScript 箭頭函數(shù) generator Date JSON
下面小編就為大家?guī)硪黄獪\析JavaScript 箭頭函數(shù) generator Date JSON。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-05-05
Function.prototype.apply()與Function.prototype.call()小結(jié)
JavaScript 中,某個(gè)函數(shù)的參數(shù)數(shù)量是不固定的,因此要說適用條件的話,當(dāng)你的參數(shù)是明確知道數(shù)量時(shí),用 call,而不確定的時(shí)候,用 apply,然后把參數(shù) push 進(jìn)數(shù)組傳遞進(jìn)去。當(dāng)參數(shù)數(shù)量不確定時(shí),函數(shù)內(nèi)部也可以通過 arguments 這個(gè)數(shù)組來便利所有的參數(shù)2016-04-04
Javascript入門學(xué)習(xí)第三篇 js運(yùn)算
上篇文章講了js中的傳值和傳址 和 函數(shù)的作用域. 這章我們來探討js中的變量,表達(dá)式,和運(yùn)算符 還有一些 js 語句。 升級中……2008-07-07
詳解JavaScript設(shè)計(jì)模式開發(fā)中的橋接模式使用
橋接模式的適用場合非常廣泛,除了在事件回調(diào)函數(shù)與接口之間進(jìn)行橋接外,橋接模式也可以用于連接公開的API代碼和私用的實(shí)現(xiàn)代碼,下面我們就來詳解JavaScript設(shè)計(jì)模式開發(fā)中的橋接模式使用2016-05-05
基于JavaScript實(shí)現(xiàn) 獲取鼠標(biāo)點(diǎn)擊位置坐標(biāo)的方法
本篇文章,小編將為大家介紹基于JavaScript實(shí)現(xiàn) 獲取鼠標(biāo)點(diǎn)擊位置坐標(biāo)的方法。有需要的朋友可以參考一下2013-04-04

