<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>Document</title>
<style type="text/css">
*{margin:0px; padding:0px;}
.small-box {
width:300px;
height:300px;
margin-left:100px;
margin-top:100px;
border:1px #ccc solid;
cursor:move;
float:left;
position:relative;
}
.small-box img {
width:300px;
height:300px;
}
.tool {
width:150px;
height:150px;
background-color:gold;
opacity:0.6;
filter:alpha(opacity=60);
position:absolute;
left:0px;
top:0px;
display:none;
}
.tool.active {
display:block;
}
.big-box {
width:300px;
height:300px;
border:1px #ccc solid;
overflow:hidden;
float:left;
margin-top:100px;
position:relative;
display:none;
}
.big-box.active {
display:block;
}
.big-box img {
width:600px;
height:600px;
position:absolute;
}
</style>
</head>
<body>
<div class="small-box" id="smallBox">
![](1.jpg)
<div class="tool" id="tool"></div>
</div>
<div class="big-box" id="bigBox">
![](1.jpg)
</div>
<script>
/*
第一步:当页面加载完后,获取所要操作的节点对象。
第二步:为smallBox添加一个鼠标浮动事件
当鼠标浮动到smallBox可视区域的时候,显示出小黄盒子tool
和右边的大盒子(小黄盒子的放大版)bigBox
添加active
为smallBox添加一个鼠标离开事件
隐藏小黄盒子和右边的大盒子
去掉active
第三步:为smallBox添加一个鼠标移动事件
小黄盒子tool要跟着鼠标的坐标移动
右边的大盒子里的图片也跟着指定的比例移动
*/
var smallBox = document.getElementById("smallBox");//小盒子
var tool = document.getElementById("tool");//小盒子中的黄色区域
var bigBox = document.getElementById("bigBox");//大盒子
var bigImg = document.getElementById("bigImg");//放大的图片
//鼠标进入小盒子区域内,显示黄色区域和大盒子
smallBox.onmouseenter = function(){
tool.className = "tool active";
bigBox.className = "big-box active";
}
//鼠标离开小盒子区域,不显示黄色区域和大盒子
smallBox.onmouseleave = function(){
tool.className = "tool";
bigBox.className = "big-box";
}
//鼠标在小盒子内移动
smallBox.onmousemove = function(e){
var _e = window.event||e;//事件对象,这一句这么写是要兼容各个浏览
var x = _e.clientX-this.offsetLeft-tool.offsetWidth/2;//事件对象在小盒子内的横向偏移量
var y = _e.clientY-this.offsetTop-tool.offsetHeight/2;//竖向偏移量
if(x<0){
x = 0;//当左偏移出小盒子时,设为0
}
if(y<0){
y = 0;//当上偏移出小盒子时,设为0
}
if(x>this.offsetWidth-tool.offsetWidth){
x = this.offsetWidth-tool.offsetWidth;//当右偏移出小盒子时,设为小盒子的宽度-黄色放大区域宽度
}
if(y>this.offsetHeight-tool.offsetHeight){
y = this.offsetHeight-tool.offsetHeight;//当下偏移出小盒子时,设为小盒子的高度-黄色放大区域高度
}
tool.style.left = x + "px";//黄色放大区域距离小盒子左偏距
tool.style.top = y + "px";//黄色放大区域距离小盒子上偏距
bigImg.style.left = -x*2 + "px";//放大图片移动方向相反,偏移距离加倍
bigImg.style.top = -y*2 + "px";
}
</script>
</body>
</html>
js放大镜
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 翻了翻为2014年写的总结,还能想起当时靠在床头、在键盘上敲击文章的感觉,清晰得像是发生在昨天。原来一年过得如此之...