js编写一个简单的产品放大效果代码


Posted in Javascript onJune 27, 2016

购物网站的产品页经常会放有一个产品展示图区。该图区有一个功能就是产品图的放大功能,移动左侧的焦点区域,可以放大细节部分观看,详情如下图。实现该功能的方法也非常简单。

 js编写一个简单的产品放大效果代码

实验:制作产品焦点放大图。

所需技能:

1、基本的获取页面元素的方法;
2、几个简单的事件;
3、会使用dom设置元素的属性;
案例原理:

1、焦点框的跟随鼠标事件;
2、焦点框的移动区域规定;
3、大盒子内容的显示;
适合对象:js初学者

-------------------------------------------------------------------开始!-------------------------------------------------------------
一、首先我们准备CSS样式,CSS样式中需要注意的几个点是:
(1)焦点图相对定位,默认display:none; 
(2)右侧显示大图的盒子(以下简称大图框)默认display:none;大图框中的内容在溢出盒子后要隐藏overflow:hidden; 

js编写一个简单的产品放大效果代码

二、开始书写script代码:
(1)首先获取页面元素:

//首先或许要操作的元素
 function getId(tag){
 //定义一个用id获取元素的方法,减少很多工作量!
  return document.getElementById(tag)
 }
 var box=getId("box");
 var small=getId("small");
 var mask=getId("mask");
 var big=getId("big");
 var pic=big.children[0];

 //这里是通过节点的方法获取元素

(2)明确鼠标移动到小图上会出现两个事件:1)焦点框要出来;2)大图框要显示出来。同理鼠标移除后这两个事假要取消 

//鼠标移动到图片上出现两个效果
 small.onmouseover=function(){
  mask.style.display="block";
  big.style.display="block";
 }
 small.onmouseout=function(){
  mask.style.display="none";
  big.style.display="none"
 }
 

(3)设置焦点框的跟随:
1)当设置焦点框的跟随时,我们的跟随时间是事实发生的,所以此处的事件类型不在是onmouseover;而是onmousemove;
2)这段代码中涉及到的问题主要是一个mask(焦点框)的定位计算问题,容易忽略的问题是mask是相对谁的位置移动的?我的css样式中mask是放在small这个盒子中的,所以相对移动的位置一定是其已经定位的父元素small的位置。所以我用clientX,clientY获取的相对于浏览器当前窗口的位置坐标不能直接使用,必须减去其父盒子的margin值的影响。

//设置小图的焦点框,跟随鼠标;
 small.onmousemove=function(e){
  var marginL=box.offsetLeft; //使用offsetLeft方法获得box的margin-left
  var marginT=box.offsetTop; //使用offsetTop方法获得box的margin-top
  var currentX= e.clientX;







  var currentY= e.clientY;
//使用e.clientX和e.clinetY相对于浏览器的左上角的位置

 
  var x=currentX-marginL-mask.offsetWidth/2;




  var y=currentY-marginT-mask.offsetHeight/2; //要想使焦点框的中心对齐鼠标,还需要减去焦点框的宽高的一半
/----------------------此处一会儿还要插入其他代码/---------------------------/
  mask.style.left=x+"px";
  mask.style.top=y+"px"; 
//改变焦点框的位置 

(4)闲置焦点框的位置的移动 
1)上一步执行完成后焦点框的移动是不受任何闲置的,在我们浏览购物网站的过程中,明显可以感受到焦点框不容许移动的小图的外面,造成不好的用户体验; 
2)要限制焦点框的移动,主要是x,y变化超过容许值时,给他一个固定的值; 

//设置小图的焦点框,跟随鼠标;
 small.onmousemove=function(e){
  var marginL=box.offsetLeft;
  var marginT=box.offsetTop;
  var currentX= e.clientX;
  var currentY= e.clientY;
  var x=currentX-marginL-mask.offsetWidth/2;
  var y=currentY-marginT-mask.offsetHeight/2;

  //给焦点框设置移动区域
  if(x<0){x=0;}
  if(x>small.offsetWidth-mask.offsetWidth)


{x=small.offsetWidth-mask.offsetWidth};

 // 用于定位的x的最小值是0,最大值是small的长度-mask的长度 y轴线同理
  if(y<0){y=0;}
  if(y>small.offsetHeight-mask.offsetHeight)




{y=small.offsetHeight-mask.offsetHeight};
  mask.style.left=x+"px";




//注意在规定移动区域后再写mask的移动区域,注意代码的执行顺序
  mask.style.top=y+"px";

(5)设置大图的显示 
1)在big盒子中实现图片的移动,应该想到-margin值; 
2)移动多少距离可以利用一个固定比例乘以mask的left和top值,想一下焦点区的左上角和大图框的左上角显示的位置是相同的!!!这一点就不是很难理解了 

//设置大盒子中显示的内容
  var relativeX=mask.offsetLeft;
  var relativeY=mask.offsetTop;
  var proporationX=pic.offsetWidth/small.offsetWidth;

//设置比例
  var proporationY=pic.offsetHeight/small.offsetWidth;
  pic.style.marginLeft=-relativeX*proporationX+"px";


//注意!margin的值必须是负值,“px不要丢掉
  pic.style.marginTop=-relativeY*proporationY+"px";

到这一步我们的这个demo也就做完了!是不是很简单
下面我将整个代码粘贴出来,希望能和大家讨论交流。

这里是css代码 

<style>
  * {
   margin: 0;
   padding: 0;
  }

  #box {
   margin: 50px;

  }

  #small {
   width: 229px;
   height: 250px;
   border: 1px solid black;
   text-align: center;
   position: relative;
   float: left;
  }

  #mask {
   width: 100px;
   height: 100px;
   background-color: rgba(214, 111, 193, 0.3);
   position: absolute;
   top: 0;
   left: 0;
   /*display: none;*/
  }
  #big {
   width: 350px;
   height: 350px;
   border: 1px solid black;
   float: left;
   overflow: hidden;
   /*display: none;*/
  }
 </style>

这里是HTML 

<body>
<div id="box">
 <div id="small">
  <img src="small_img.jpg" width="229" height="249" alt=""/>

  <div id="mask"></div>
 </div>
 <div id="big">
  <img src="big_img.JPG" width="549" height="600" alt=""/>
 </div>
</div>

这里是js代码 

<script>
 //首先或许要操作的元素
 function getId(tag){
  return document.getElementById(tag)
 }
 var box=getId("box");
 var small=getId("small");
 var mask=getId("mask");
 var big=getId("big");
 var pic=big.children[0];
 console.log(pic);
 //鼠标移动到图片上出现两个效果
 small.onmouseover=function(){
  mask.style.display="block";
  big.style.display="block";
 }
 small.onmouseout=function(){
  mask.style.display="none";
  big.style.display="none"
 }
  //设置小图的焦点框,跟随鼠标;
 small.onmousemove=function(e){
  var marginL=box.offsetLeft;
  var marginT=box.offsetTop;
  var currentX= e.clientX;
  var currentY= e.clientY;
  var x=currentX-marginL-mask.offsetWidth/2;
  var y=currentY-marginT-mask.offsetHeight/2;

  //给焦点框设置移动区域
  if(x<0){x=0;}
  if(x>small.offsetWidth-mask.offsetWidth){x=small.offsetWidth-mask.offsetWidth};
  if(y<0){y=0;}
  if(y>small.offsetHeight-mask.offsetHeight){y=small.offsetHeight-mask.offsetHeight};
  mask.style.left=x+"px";
  mask.style.top=y+"px";
  //设置大盒子中显示的内容
  var relativeX=mask.offsetLeft;
  var relativeY=mask.offsetTop;
  var proporationX=pic.offsetWidth/small.offsetWidth;
  var proporationY=pic.offsetHeight/small.offsetWidth;
  pic.style.marginLeft=-relativeX*proporationX+"px";
  pic.style.marginTop=-relativeY*proporationY+"px";
 }
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
拖拉表格的JS函数
Nov 20 Javascript
js关闭子窗体刷新父窗体实现方法
Dec 04 Javascript
node.js中的fs.closeSync方法使用说明
Dec 17 Javascript
sails框架的学习指南
Dec 22 Javascript
js实现文件上传表单域美化特效
Nov 02 Javascript
浏览器环境下JavaScript脚本加载与执行探析之defer与async特性
Jan 14 Javascript
原生js实现鼠标跟随效果
Feb 28 Javascript
vue2.0多条件搜索组件使用详解
Mar 26 Javascript
利用JS如何计算字符串所占字节数示例代码
Sep 13 Javascript
详解vue.js数据传递以及数据分发slot
Jan 20 Javascript
jQuery pjax 应用简单示例
Sep 20 jQuery
vue中使用element ui的弹窗与echarts之间的问题详解
Oct 25 Javascript
用JS实现轮播图效果(二)
Jun 26 #Javascript
用JS实现图片轮播效果代码(一)
Jun 26 #Javascript
JavaScript中Form表单技术汇总(推荐)
Jun 26 #Javascript
jQuery滚动新闻实现代码
Jun 26 #Javascript
js css实现垂直方向自适应的三角提示菜单
Jun 26 #Javascript
JS中的进制转换以及作用
Jun 26 #Javascript
JavaScript类型系统之布尔Boolean类型详解
Jun 26 #Javascript
You might like
让你成为更出色的PHP开发者的10个技巧
2011/02/25 PHP
thinkphp在模型中自动完成session赋值示例代码
2014/09/09 PHP
javascript生成/解析dom的CDATA类型的字段的代码
2007/04/22 Javascript
jQuery ready函数滥用分析
2011/02/16 Javascript
javascript实现删除前弹出确认框
2015/06/04 Javascript
JavaScript forEach()遍历函数使用及介绍
2015/07/08 Javascript
JQuery zClip插件实现复制页面内容到剪贴板
2015/11/02 Javascript
基于Vue.js的表格分页组件
2016/05/22 Javascript
JavaScript数据存储 Cookie篇
2016/07/02 Javascript
js判断浏览器是否支持严格模式的方法
2016/10/04 Javascript
解析JavaScript数组方法reduce
2016/12/12 Javascript
AngularJs篇:使用AngularJs打造一个简易权限系统的实现代码
2016/12/26 Javascript
安装vue-cli报错 -4058 的解决方法
2017/10/19 Javascript
基于js中的存储键值对以及注意事项介绍
2018/03/30 Javascript
看看“疫苗查询”小程序有温度的代码
2018/07/31 Javascript
vue2.0结合Element-ui实战案例
2019/03/06 Javascript
js+html实现周岁年龄计算器
2019/06/25 Javascript
Vue Components 数字键盘的实现
2019/09/18 Javascript
[59:42]Secret vs Alliacne 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
学习python (1)
2006/10/31 Python
python实现简单的socket server实例
2015/04/29 Python
Centos部署django服务nginx+uwsgi的方法
2019/01/02 Python
Python+Dlib+Opencv实现人脸采集并表情判别功能的代码
2020/07/01 Python
如何提高MySql的安全性
2014/06/19 面试题
合同协议书格式
2014/04/18 职场文书
基本公共卫生服务健康教育工作方案
2014/05/22 职场文书
参赛口号
2014/06/16 职场文书
2014年机关工会工作总结
2014/12/19 职场文书
办公室个人总结
2015/02/28 职场文书
乒乓球比赛通知
2015/04/27 职场文书
什么是创业计划书?什么是商业计划书?这里一一解答
2019/07/12 职场文书
女人创业励志语录,句句蕴含能量,激发你的潜能
2019/08/20 职场文书
教你用Python matplotlib库制作简单的动画
2021/06/11 Python
PyMongo 查询数据的实现
2021/06/28 Python
Spring Boot两种全局配置和两种注解的操作方法
2021/06/29 Java/Android
PYTHON基于Pyecharts绘制常见的直角坐标系图表
2022/04/28 Python