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 相关文章推荐
asp(javascript)全角半角转换代码 dbc2sbc
Aug 06 Javascript
JQuery 弹出框定位实现方法
Dec 02 Javascript
Javascript 多浏览器兼容总结(实战经验)
Oct 30 Javascript
浅析AngularJS Filter用法
Dec 28 Javascript
深入理解jQuery之防止冒泡事件
May 24 Javascript
老生常谈 js中this的指向
Jun 30 Javascript
Bootstrap插件全集
Jul 18 Javascript
jquery.uploadifive插件怎么解决上传限制图片或文件大小问题
May 08 jQuery
mui开发中获取单选按钮、复选框的值(实例讲解)
Jul 24 Javascript
jquery实现企业定位式导航效果
Jan 01 jQuery
微信小程序地图实现展示线路
Jul 29 Javascript
JS跨浏览器解析XML应用过程详解
Oct 16 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编程最快明白》第三讲:php数组
2010/11/01 PHP
php去除字符串中空字符的常用方法小结
2015/03/17 PHP
php使用Jpgraph绘制饼状图的方法
2015/06/10 PHP
使用PHP实现下载CSS文件中的图片
2015/12/06 PHP
PHP基于socket实现客户端和服务端通讯功能
2017/07/13 PHP
PHP 数组黑名单/白名单实例代码详解
2019/06/04 PHP
在 Laravel 项目中使用 webpack-encore的方法
2019/07/21 PHP
浅谈Javascript事件模拟
2012/06/27 Javascript
js关闭当前页面(窗口)的几种方式总结
2013/03/05 Javascript
js select option对象小结
2013/12/20 Javascript
JSONP获取Twitter和Facebook文章数的具体步骤
2014/02/24 Javascript
jquery 根据name名获取元素的value值
2015/02/27 Javascript
JavaScript判断前缀、后缀是否是空格的方法
2015/04/15 Javascript
IE7浏览器窗口大小改变事件执行多次bug及IE6/IE7/IE8下resize问题
2015/08/21 Javascript
Angularjs使用ng-repeat中$even和$odd属性的注意事项
2016/12/31 Javascript
JavaScript门面模式详解
2017/10/19 Javascript
JS实现监控微信小程序的原理
2018/06/15 Javascript
详解vue中axios请求的封装
2019/04/08 Javascript
JavaScript实现京东快递单号查询
2020/11/30 Javascript
python实现颜色rgb和hex相互转换的函数
2015/03/19 Python
Python 基础知识之字符串处理
2017/01/06 Python
Python读取Excel表格,并同时画折线图和柱状图的方法
2018/10/14 Python
Python箱型图绘制与特征值获取过程解析
2019/10/22 Python
python环境下安装opencv库的方法
2020/03/05 Python
Django-celery-beat动态添加周期性任务实现过程解析
2020/11/26 Python
python 6种方法实现单例模式
2020/12/15 Python
韩国CJ食品专卖网:CJonmart
2016/09/11 全球购物
阿里健康大药房:阿里自营网上药店
2017/08/01 全球购物
党的群众路线教育实践活动对照检查材料思想汇报
2014/09/19 职场文书
骨干教师申报材料
2014/12/17 职场文书
博士给导师的自荐信
2015/03/06 职场文书
丧事主持词
2015/07/02 职场文书
怎样写工作总结啊!
2019/06/18 职场文书
职场中的你,辞职信写对了吗?
2019/06/26 职场文书
用Java实现简单计算器功能
2021/07/21 Java/Android
Python 一键获取电脑浏览器的账号密码
2022/05/11 Python