JavaScript--放大镜
上例图:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<style>
* {
margin: 0;
padding: 0;
} .box {
width: 350px;
height: 467px;
margin: 100px;
border: 1px solid #ccc;
position: relative;
/*overflow: hidden;*/
} .big {
width: 400px;
height: 400px;
position: absolute;
top: 0;
left: 360px;
border: 1px solid #ccc;
overflow: hidden;
/*display: none;*/
opacity: 0.1;
z-index: -1;
/*transform: translateX(-500px) scale(0);*/
transition: all .4s;
} .mask {
width: 175px;
height: 175px;
background: rgba(255, 255, 0, 0.4);
position: absolute;
top: 0px;
left: 0px;
cursor: move;
display: none;
} .small {
position: relative;
}
.box:hover .mask{
display: block;
}
.box:hover .big{
transform: translateX(0px) scale(1);
opacity: 1;
z-index: 1;
/*display: block;*/
}
</style>
</head>
<body>
<div class="box" id="box">
<div class="small"><!--小层-->
<img src="img/small2.jpg" width="350" alt=""/>
<div class="mask" id="mask"></div><!--遮挡层-->
</div>
<div class="big" id="big"><!--大层-->
<img src="img/big2.jpg" width="800" alt=""/><!--大图-->
</div>
</div>
</body>
</html>
<script>
/*以下注释的代码用CSS代替了*/
// var box = document.getElementById("box");
// var mask = document.getElementById("mask");
// var big = document.getElementById("big"); // box.onmouseover = function () {
// mask.style.display = "block";
// big.style.display = "block";
// }
// box.onmouseout = function () {
// mask.style.display = "none";
// big.style.display = "none";
// } /**
* 1.鼠标移上大分区,遮罩层和大图显示
* 2.鼠标移出大分区,遮罩层和大图隐藏
* 3.鼠标在大分区内移动的时候,遮罩层跟鼠标移动,大图也跟着移动
* */ var box = document.getElementById("box");
var mask = document.getElementById("mask");
var bigImg = document.getElementById("big").children[0];
box.onmousemove = function (event) {
var pageX = event.pageX;
var pageY = event.pageY;
// 数据有了,我们希望盒子跟着鼠标走
// 由于盒子是绝对定位,所以基于页面获取到的坐标要做处理
// 目标数据 = 鼠标在页面的坐标 - 大盒子距离页面的坐标
var boxOffsetLeft = box.offsetLeft ;
var boxOffsetTop = box.offsetTop;
var boxOffsetWidth = box.offsetWidth;
var boxOffsetHeight = box.offsetHeight; var maskOffsetWidth = mask.offsetWidth;
var maskOffseetHeight = mask.offsetHeight;
// 让鼠标在mask盒子中心拖拽移动
var mX = pageX - boxOffsetLeft -maskOffsetWidth/2;
var mY = pageY - boxOffsetTop - maskOffseetHeight/2;
// 以下判断mask盒子是否越出父盒子
if(mX < 0) {
mX = 0 ;
}
if(mY < 0) {
mY = 0 ;
}
if(mX > boxOffsetWidth - maskOffsetWidth) {
mX = boxOffsetWidth -maskOffsetWidth;
}
if(mY > boxOffsetHeight - maskOffseetHeight) {
mY = boxOffsetHeight - maskOffseetHeight;
}
// 设置mask盒子位置
mask.style.left = mX + "px";
mask.style.top = mY + "px";
// 获取比例设置大图等比例的位置
var bili = bigImg.offsetWidth/boxOffsetWidth;
bigImg.style.marginLeft = -mX*bili + "px";
bigImg.style.marginTop = -mY*bili + "px"; } </script>
JavaScript--放大镜的更多相关文章
- javascript放大镜效果
JS实现放大镜效果 首先我们先设想一下放大镜效果 1.当鼠标进入小盒子的时候,把大图片显示出来 2.当指定移动区域的时候,显示当前放大区域(放大效果) 3.鼠标移除我们让它消失 一.实现页面布局HTM ...
- JavaScript之放大镜效果
在网上也浏览过许多关于JavaScript放大镜效果的文章,有的代码解释得些隐晦难懂,看的我头有点晕晕的╮(╯﹏╰)╭,我的心情是这样的: 吐槽完了,我们动动小鼠标,当鼠标经过下面这张美女图片时就实现 ...
- 【JavaScript】放大镜效果
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- [原创] JavaScript 图片放大镜插件 enlarge.js 以及移动版 enlarge.touch.js
拖拖拉拉准本了一个月,终于把网站做好了.也终于可以分享这两个插件了.这两个插件,一个是 jQuery 版本,适合鼠标使用的,另一个是原生 JavaScript 制作,适合触摸屏使用(touch 事件) ...
- JavaScript之放大镜效果2
在放大图片效果的同时,我们怎么原图和放大窗体增加间隔呢? 我们只需应用一个table就行了: 源码上: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML ...
- 原生javascript实现图片放大镜效果
当我们在电商网站上购买商品时,经常会看到这样一种效果,当我们把鼠标放到我们浏览的商品图片上时,会出现类似放大镜一样的一定区域的放大效果,方便消费者观察商品.今天我对这一技术,进行简单实现,实现图片放大 ...
- 从零开始学习前端JAVASCRIPT — 11、JavaScript运动模型及轮播图效果、放大镜效果、自适应瀑布流
未完待续...... 一.运动原理 通过连续不断的改变物体的位置,而发生移动变化. 使用setInterval实现. 匀速运动:速度值一直保持不变. 多物体同时运动:将定时器绑设置为对象的一个属性. ...
- javascript 实现图片放大镜功能
淘宝上经常用到的一个功能是利用图片的放大镜功能来查看商品的细节 下面我们来实现这样一个功能吧,原理很简单: 实现一个可以随鼠标移动的虚框 在另外一个块中对应显示虚框中的内容 实现思路: 虚框用css中 ...
- javascript图片放大镜效果展示
javascript图片放大镜效果展示 <!DOCTYPE html> <html> <head lang="en"> <meta cha ...
- JavaScript仿淘宝实现放大镜效果的实例
我们都知道放大镜效果一般都是用于一些商城中的,列如每当我们打开淘宝,天猫等pc端时,看到心仪的物品时,点击图片时,便呈现出放大镜的效果.在没有去理解分析它的原理时,感觉非常的神奇,当真正地去接触,也是 ...
随机推荐
- 百度ueditor解决页面组件被覆盖问题
本文不再更新,可能存在内容过时的情况,实时更新请移步原文地址:百度ueditor解决页面组件被覆盖问题: 在使用ueditor的过程中,会出现表单组件被ueditor覆盖的问题,解决的方式如下: ue ...
- Python :route的用法以及Http方法
现代 Web 应用的 URL 十分优雅,易于人们辨识记忆,这一点对于那些面向使用低速网络连接移动设备访问的应用特别有用.如果可以不访问索引页,而是直接访问想要的那个页面,他们多半会笑逐颜开而再度光顾. ...
- C++与Matlab混合编程之:矩阵数据结构
项目需要将matlab代码写成C++,准备用opencv.opencv中矩阵的存储与matlab有所不同,应注意以下问题: 1.matlab中矩阵是按照列优先存储的.对于n0*n1*...*nn维的矩 ...
- Java的跨平台特性
语言跨平台是编译后的文件跨平台,而不是源程序跨平台.Java源代码首先经过编译器生成字节码,即class文件,该class文件与平台无关,而class文件经过解释执行之后翻译成最终的机器码,这是平台相 ...
- 19-10-16-R
其实……这篇是真咕了. 反思: ××我$T1$两个小时构造$xiebi$了(虽然我觉得如果干仨小时可能行?) ……如果$T1$用时过长的话那考试多半不行…… 结果: 35 Miemeng 50 03: ...
- 使用Scrapyd部署Scrapy爬虫到远程服务器上
1.准备好爬虫程序 2.修改项目配置 找到项目配置文件scrapy.cnf,将里面注释掉的url解开来 本代码需要连接数据库,因此需要修改对应的数据库配置 其实就是将里面的数据库地址进行修改,变成远程 ...
- win10上的vs2015项目到win7的2015无法使用
- 读取复杂结构的yml配置项
1.yml配置项示例:(List的集合在第一项前面加 “-”) rabbitmqsetting: exchangeList: - name: e1 type: topic bindingList: - ...
- PHP实现git部署的方法,可以学学!
https://mp.weixin.qq.com/s/QFpKu8oKoxOEA1BmT7pNhg 在小站点上,直接用git来部署php代码相当方便,你的远程站点以及本地版本库都有一个版本控制,追 ...
- html中有序列表标签ol,li的高级应用
本文主要介绍html中有序列表标签ol,li的高级应用, 在网页设计时我们设计有序列表内容时,经常会在每个ITEM前手工加上一个数值,或是由程序加上这个数值. 而如果使用有序列表标签ol和li,则不需 ...