基本信息
源码名称:JS实现放大镜效果
源码大小:0.93M
文件格式:.rar
开发语言:js
更新时间:2018-06-04
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="Generator" content="EditPlus®">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<title>JS实现放大镜查看大图效果</title>
<style>
*{
margin:0;
padding:0;
}
#product{
position:relative;
width:100%;
height:640px;
}
.mid-box{
position:absolute;
top:10px;
left:10px;
float:left;
width:350px;
height:449px;
border:1px solid #747474;
text-align:center;
vertical-align:middle;
z-index:5;
}
.mid-box > img{
position:absolute;
top:0;
left:0;
}
.mid-box .move-slider{
display:none;
position:absolute;
top:0;
left:-50%;
width:175px;
height:50%;
background-color:rgba(234,218,147,.6);
cursor:move;
z-index:10;
}
.small-box{
position:absolute;
left:20px;
bottom:113px;
width:380px;
height:64px;
}
.small-box li{
list-style-type:none;
float:left;
height:64px;
margin-right:6px;
}
.small-box li.on{
border:1px solid red;
}
.big-box{
display:none;
position:absolute;
top:10px;
left:368px;
float:left;
overflow:hidden;
width:400px;
height:513px;
border:1px solid #747474;
z-index:5;
}
.big-box .bigImg{
position:relative;
top:0px;
left:0px;
}
</style>
<script type="text/javascript">
window.onload=function(){
var productBox=document.getElementById("product");
var midBox=productBox.getElementsByClassName("mid-box")[0];
var bigBox=productBox.getElementsByClassName("big-box")[0];
var moveSlider=productBox.getElementsByClassName("move-slider")[0];
var midImg=productBox.getElementsByTagName("img")[0];
var smallImg=productBox.getElementsByTagName("li");
var bigImg=productBox.getElementsByClassName("bigImg")[0];
for(var i=0;i<smallImg.length;i ){
smallImg[i].onmouseover=function(){
for(var j=0;j<smallImg.length;j ){
smallImg[j].className='';
}
this.className='on';
midImg.src=this.getAttribute('data-mid');
bigImg.src= this.getAttribute('data-big');
}
}
midBox.onmouseenter=function(){
moveSlider.style.display="block";
bigBox.style.display="block";
}
midBox.onmouseleave=function(){
moveSlider.style.display="none";
bigBox.style.display="none";
}
function pos(e){
var scrollTop=document.documentElement.scrollTop || document.body.scrollTop;
var scrollLeft=document.documentElement.scrollLeft || document.body.scrollLeft;
return json={x:scrollLeft e.clientX,y:scrollTop e.clientY};
}
midBox.onmousemove=function(e){
var e=e || event;//事件源的兼容问题
var midBox_top=midBox.offsetTop;
var midBox_left=midBox.offsetLeft;
var disX=pos(e).x-midBox_left;
var disY=pos(e).y-midBox_top;
var move_top=disY-moveSlider.offsetHeight/2;
var move_left=disX-moveSlider.offsetWidth/2;
var max_top=midBox.offsetHeight-moveSlider.offsetHeight;
var max_left=midBox.offsetWidth-moveSlider.offsetWidth;
var bigmax_top=bigImg.offsetHeight-bigBox.offsetHeight;
var bigmax_left=bigImg.offsetWidth-bigBox.offsetWidth;
move_top=move_top<=0 ? 0 : move_top;
move_top=move_top>=max_top ? max_top : move_top;
move_left=move_left<=0 ? 0 : move_left;
move_left=move_left>=max_left ? max_left : move_left;
moveSlider.style.top=move_top 'px';
moveSlider.style.left=move_left 'px';
var scaleX=move_left/max_left;
var scaleY=move_top/max_top;
var bigimg_top=bigmax_top*scaleY;
var bigimg_left=bigmax_left*scaleX;
bigImg.style.top=-bigimg_top 'px';
bigImg.style.left=-bigimg_left 'px';
}
}
</script>
</head>
<body>
<div id="product">
<!--中图区域-->
<div class="mid-box">
<img src="images/mid1.jpg" alt="" width="100%" height="100%">
<div class="move-slider"></div>
</div>
<!--小图区域-->
<div class="small-box">
<ul>
<li class="on" data-mid="images/mid1.jpg" data-big="images/big1.jpg">
<img src="images/small1.jpg" alt="" width="50" height="64">
</li>
<li data-mid="images/mid2.jpg" data-big="images/big2.jpg">
<img src="images/small2.jpg" alt="" width="50" height="64">
</li>
<li data-mid="images/mid3.jpg" data-big="images/big3.jpg">
<img src="images/small3.jpg" alt="" width="50" height="64">
</li>
<li data-mid="images/mid4.jpg" data-big="images/big4.jpg">
<img src="images/small4.jpg" alt="" width="50" height="64">
</li>
<li data-mid="images/mid5.jpg" data-big="images/big5.jpg">
<img src="images/small5.jpg" alt="" width="50" height="64">
</li>
<li data-mid="images/mid6.jpg" data-big="images/big6.jpg">
<img src="images/small6.jpg" alt="" width="50" height="64">
</li>
</ul>
</div>
<!--大图区域-->
<div class="big-box">
<img class="bigImg" src="images/big1.jpg" alt="" width="800" height="1026">
</div>
</div>
</body>
</html>