Rumah  >  Artikel  >  hujung hadapan web  >  利用jQuery实现图片放大镜

利用jQuery实现图片放大镜

善始善终
善始善终asal
2020-12-08 12:17:322912semak imbas

推荐:《jquery视频教程

一、需求分析

图片的放大效果我们在软件开发中经常遇到,其相当于放大镜效果。我们在平时的网购中可以看到,我们在浏览一商品时,单击一张图片,其左侧会展示一张商品的图片,当鼠标移动到图片上时就会在右侧展示局部放大的效果

二、设计思路

1、当鼠标移入到小图的盒子时,如何显示放大镜盒子和大图盒子?

2、如何获取小图图片和大图图片的宽度和高度?

3、如何设置放置小图盒子的宽度

4、如何设置放大镜滑块和盒子的大小

5、何设置放大镜盒子移动事件

6、如何设置鼠标在放大镜盒子的中心上?

7、如何设置使放大镜盒子不可以出边框?

8、如何设置大图跟着放大镜盒子移动?

9、放大的图片的移动距离如何设置?

10、如何计算放大的图片的移动距离?

11、当鼠标移入到小图的盒子时,如何隐藏放大镜盒子和大图盒子?

三、知识储备

1. 实现图片放大镜的原理:

(1)给放大镜元素一个对应的html元素为dc6dce4a544fdca2df29d5ac0ea9906b

(2)设置这个div的宽高固定为某个值;

(3)设置div的css为超出部分隐藏;

(4)div中嵌套子元素img设置宽高固定为某个值;

(5)通过数学函数计算,移动div的x轴和y轴的滚动条,正好让放大镜显示鼠标在大图的那一块区域。

2. jQuery选择器的分类

0501.png

3. 常见的jQuery事件

(1)页面对不同访问者的响应叫做事件。事件处理程序指的是当 HTML 中发生某些事件时所调用的方法。常见的事件有:在元素上移动鼠标、选取单选按钮、点击元素…

(2)在事件中经常使用术语"触发"(或"激发")例如: "当您按下按键时触发 keypress 事件"。

0502.png

4. 鼠标位置获取。

0503.png

5. jQuery中的常见的DOM操作:查找元素、遍历元素、创建元素、插入元素、删除元素、替换元素、复制元素、属性操作、样式操作、HTML操作。&oq=查找元素、遍历元素、创建元素、插入元素、删除元素、替换元素、复制元素、属性操作、样式操作、HTML操作。

四、代码实现

1、在页面布局的DIV下添加三个DIV标签;

975d0942adc81abcb9d3625a06484914

              <div>
                     <!-- 盒子中的图片 -->
                     <img src="img/1.jpg" alt="">
                     <!—定义一个盒子来存放放大镜 -->
                     <div></div>
              </div>
              <!—定义一个盒子来存放放大后图片-->
              <div>
                     <img src="img/1.jpg" alt="">
              </div>

2、使用CSS进行美化

l  全局样式

*{
              margin: 0;
              padding: 0;
}

l  .small样式

.small{
                     position: relative;
                     height: 400px;
                     margin-left: 5px;
              }

l  .small img样式

.small img{
                     height: 360px;
                     width:  620px;
              }

l  .box样式

.box{
                     position: absolute;
                     background: rgba(254, 238, 167, .4);
                     left:0;
                     top: 0;
                     display: none;
                     cursor: crosshair;
              }

l  .big样式

.big{
                     position:absolute;
                     top: 0px;
                     left:410px;
                     width: 600px;
                     height: 360px;
                     overflow: hidden;
                     display: none;
              }

l  .big img样式

.big img{
                     position: relative;
              }

3、使用jQuery实现效果

1)    将放大镜盒子和大图盒子显示出来,代码如下:

$(&#39;.box&#39;).show();
$(&#39;.big&#39;).show();

2)  获取小图片的宽度和高度,代码如下:

var width = $(&#39;.small img&#39;).width();
var height=$(&#39;.small img&#39;). height ();

3)  获取大图片的宽度和高度,代码如下:

var Bwidth = $(&#39;.big img&#39;).width();
var Bheight = $(&#39;.big img&#39;).height();

4)  设置放置小图盒子的宽度,代码如下:

$(&#39;.small&#39;).css(&#39;width&#39;,width+&#39;px&#39;);

5)  设置放大镜滑块的大小,代码如下:

var Hwidth = ($(&#39;.big&#39;).width())/Bwidth*($(&#39;.small&#39;).width());
var Hheight = ($(&#39;.big&#39;).height())/Bheight*($(&#39;.small&#39;).height());

6)  设置放大镜盒子的大小

$(&#39;.box&#39;).css({&#39;width&#39;:Hwidth + &#39;px&#39;,&#39;height&#39;:Hheight + &#39;px&#39;});

7)  设置放大镜盒子移动事件

$(&#39;.small&#39;).mousemove(function(e){
//获取鼠标的位置,代码如下:
var x = e.clientX;
var y = e.clientY;
//设置鼠标在放大镜盒子的中心上,代码如下:
var xx = x - $(&#39;.box&#39;).width()/2;
var yy = y -$(&#39;.box&#39;).height()/2;
//设置使放大镜盒子不可以出边框,代码如下:
var maxX = $(&#39;.small&#39;).width()-$(&#39;.box&#39;).width();
var maxY = $(&#39;.small&#39;).height()-$(&#39;.box&#39;).height();
if (xx<0) {
    xx = 0;
}
if (xx>maxX) {
    xx = maxX;
}
if (yy<0){
    yy = 0;
}
if (yy>maxY){
    yy = maxY;
}
$(&#39;.box&#39;).css({&#39;left&#39;:xx + &#39;px&#39;,&#39;top&#39;:yy + &#39;px&#39;});
//查看放大的倍数,及大图的移动距离,放大的图片的移动距离为放大镜盒子移动的距离*放大的倍数。代码如下:
var img_x = xx * ($(&#39;.big img&#39;).width()/$(&#39;.small img&#39;).width());
var img_y = yy * ($(&#39;.big img&#39;).height()/$(&#39;.small img&#39;).height());
//设置放大的图片的移动。代码如下:
$(&#39;.big img&#39;).css({&#39;left&#39;:-img_x + &#39;px&#39;,&#39;top&#39;:-img_y + &#39;px&#39;});
//创建当鼠标移入到小图的盒子时事件,将放大镜盒子和大图盒子进行隐藏。代码如下:
$(&#39;.small&#39;).mouseout(function(){
       $(&#39;.box&#39;).hide();
       $(&#39;.big&#39;).hide();
}) 
})

五、结果展示

0601.png

Atas ialah kandungan terperinci 利用jQuery实现图片放大镜. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn