js實(shí)現(xiàn)簡單放大鏡效果
用js實(shí)現(xiàn)簡單放大鏡效果,供大家參考,具體內(nèi)容如下
此處放大鏡實(shí)現(xiàn)的效果就是當(dāng)鼠標(biāo)放置在圖片上會(huì)有半透明遮罩,圖片的一個(gè)區(qū)域就會(huì)被放大,然后展示在右邊。當(dāng)鼠標(biāo)移動(dòng)時(shí)右邊的大圖片也會(huì)局部移動(dòng)。這里的放大并不是真正的放大,而是等比例移動(dòng)。下面是實(shí)現(xiàn)的代碼:
css樣式代碼如下:
<style>
.s_box{width:400px;height: 300px;position: absolute;left: 50px;top:100px;}
.s_box img{width: 400px;height: 300px;}
.s_box span{width: 130px;height: 100px;background: rgba(200,200,200,0.5);position: absolute;left:0;top:0;display: none;cursor:move;}
.b_box{width: 400px;height: 300px;overflow: hidden;position: absolute;left:500px;top:100px;display: none;}
.b_box img{width: 1200px;height: 900px;position: absolute;left:0;top:0;}
.list{margin: 0;padding: 0;list-style: none;position: absolute;left:50px;top:430px;}
.list li{float: left;margin: 0 10px;}
.list li img{width: 100px;height: 80px;}
</style>
html代碼如下:
<body> <div class="s_box"> <img src="../img/large1.jpg" alt=""> <span></span> </div> <div class="b_box"> <img src="../img/large1.jpg" alt=""> </div> <ul class="list"> <li><img src="../img/large1.jpg" alt=""></li> <li><img src="../img/large2.jpg" alt=""></li> </ul> </body>
js主要代碼如下:
// 分析:
// 1.選擇元素
// 2.綁定事件
// 3.進(jìn)入的時(shí)候顯示元素
// 4.移動(dòng):遮罩層跟隨鼠標(biāo)移動(dòng)的同時(shí)計(jì)算遮罩層的移動(dòng)比例 、右側(cè)大圖,等比例移動(dòng)
// 5.離開的時(shí)候隱藏元素
<script>
class Large{
constructor(){
this.sBox = document.querySelector(".s_box");
this.sImg = document.querySelector(".s_box img");
this.sSpan = document.querySelector(".s_box span");
this.bBox = document.querySelector(".b_box");
this.bImg = document.querySelector(".b_box img");
// 點(diǎn)擊小圖切換大圖的按鈕
this.li = document.querySelectorAll(".list li");
}
addEvent(){
var that = this;
this.sBox.onmouseover = function(){
that.over();
}
this.sBox.onmousemove = function(eve){
var e = eve || window.event;
that.move(e);
}
this.sBox.onmouseout = function(){
that.out();
}
// 切換圖片按鈕的點(diǎn)擊事件:根據(jù)布局做出調(diào)整
for(var i=0;i<this.li.length;i++){
this.li[i].onclick = function(){
that.sImg.src = this.children[0].src;
that.bImg.src = this.children[0].src;
}
}
}
over(){
this.sSpan.style.display = "block";
this.bBox.style.display = "block";
}
move(e){
// 計(jì)算遮罩層跟隨鼠標(biāo)移動(dòng)時(shí)的left和top
var l = e.pageX - this.sBox.offsetLeft - this.sSpan.offsetWidth/2;
var t = e.pageY - this.sBox.offsetTop - this.sSpan.offsetHeight/2;
// 邊界限定
if(l<0) l=0;
if(t<0) t=0;
if(l > this.sBox.offsetWidth - this.sSpan.offsetWidth){
l = this.sBox.offsetWidth - this.sSpan.offsetWidth;
}
if(t > this.sBox.offsetHeight - this.sSpan.offsetHeight){
t = this.sBox.offsetHeight - this.sSpan.offsetHeight;
}
// 設(shè)置遮罩層的位置
this.sSpan.style.left = l + "px";
this.sSpan.style.top = t + "px";
// 根據(jù)遮罩層移動(dòng)的距離計(jì)算比例
var x = l / (this.sBox.offsetWidth - this.sSpan.offsetWidth);
var y = t / (this.sBox.offsetHeight - this.sSpan.offsetHeight);
// 根據(jù)上一步得到的比例,計(jì)算右側(cè)大圖要移動(dòng)的當(dāng)前值
this.bImg.style.left = (this.bBox.offsetWidth - this.bImg.offsetWidth) * x + "px";
this.bImg.style.top = (this.bBox.offsetHeight - this.bImg.offsetHeight) * y + "px";
}
out(){
this.sSpan.style.display = "none";
this.bBox.style.display = "none";
}
}
// 啟動(dòng)
var l = new Large();
l.addEvent();
</script>
實(shí)現(xiàn)效果:

更多關(guān)于放大鏡的精彩文章,請點(diǎn)擊鏈接查看:《放大鏡效果》
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
利用js 進(jìn)行輸入框自動(dòng)匹配字符的小例子
制作論壇用到的輸入框~想模仿百度之類的寫一個(gè)自動(dòng)匹配字符2013-06-06
利用JS實(shí)現(xiàn)AI自動(dòng)玩貪吃蛇
這篇文章主要為大家詳細(xì)介紹了如何利用JS實(shí)現(xiàn)AI版自動(dòng)玩貪吃蛇小游戲,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)JS游戲開發(fā)有一定幫助,需要的可以參考一下2022-06-06
Bootstrap標(biāo)簽頁(Tab)插件切換echarts不顯示問題的解決
這篇文章主要給大家介紹了關(guān)于Bootstrap標(biāo)簽頁(Tab)插件切換echarts不顯示問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07
原生js實(shí)現(xiàn)移動(dòng)端觸摸輪播的示例代碼
下面小編就為大家分享一篇原生js實(shí)現(xiàn)移動(dòng)端觸摸輪播的示例代碼,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12
layui.tree組件的使用以及搜索節(jié)點(diǎn)功能的實(shí)現(xiàn)
今天小編就為大家分享一篇layui.tree組件的使用以及搜索節(jié)點(diǎn)功能的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
JavaScript實(shí)現(xiàn)打印星型金字塔功能實(shí)例分析
這篇文章主要介紹了JavaScript實(shí)現(xiàn)打印星型金字塔功能,結(jié)合具體實(shí)例形式分析了javascript針對輸出任意給定行數(shù)星型金字塔圖形的原理與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-09-09
uni-app小程序沉浸式導(dǎo)航實(shí)現(xiàn)的全過程
在跨端項(xiàng)目開發(fā)中,uniapp是個(gè)不錯(cuò)的框架,下面這篇文章主要給大家介紹了關(guān)于uni-app小程序沉浸式導(dǎo)航實(shí)現(xiàn)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10
js 能實(shí)現(xiàn)監(jiān)聽F5頁面刷新子iframe 而父頁面不刷新的方法
下面小編就為大家?guī)硪黄猨s 能實(shí)現(xiàn)監(jiān)聽F5頁面刷新子iframe 而父頁面不刷新的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11

