jQuery实现鼠标滑过图片放大效果

首先,我们来看最简单的效果,就是当鼠标滑过时,图片在网页空白区域出现放大效果。具体如下图所示:
这里写图片描述
HTML代码如下:

<ul>
        <li><img src="images\Japan01.jpg" width="300px" height="200px" class="Japan" title="日本风景图"></li>
        <li><img src="images\Japan02.jpg" width="300px" height="200px" class="Japan" title="日本风景图"></li>
        <li><img src="images\Japan03.jpg" width="300px" height="200px" class="Japan" title="日本风景图"></li>
        <li><img src="images\Japan04.jpg" width="300px" height="200px" class="Japan" title="日本风景图"></li>
        <li><img src="images\Japan05.jpg" width="300px" height="200px" class="Japan" title="日本风景图"></li>
    </ul>

然后设置CSS样式:

    li{
        list-style-type: none;
        float: left;
    }
    img{
        border: 1px solid #000;
        margin-right: 20px;
        margin-top: 20px;
    }

要想实现鼠标滑过图片出现放大效果,就要给图片添加mouseover和mouseout事件。具体的思路是:

①当鼠标滑到图片时,创建一个<div>元素,内容为该图片的放大版,然后赋值给一个变量,再使用append() 方法将该元素添加给<body>

②当鼠标滑出图片时,移除<div> 元素
具体的jQuery代码如下:

   $(function(){
        $("img.Japan").mouseover(function(e){
            var landscape="<div id='landscape'><img src='"+this.src+"' alt='风景预览图' width='400px' height='300px'/></div>";
            $("body").append(landscape);
        }).mouseout(function(){
                $("#landscape").remove();
            })
    })
                  欢迎各类指正和改进代码
  • 5
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
实现鼠标悬停图片放大效果,可以通过以下几种方式: 1. 使用CSS transform属性 可以使用CSS的transform属性来实现图片放大效果。将图片的缩放比例设为1.2或其他比例,当鼠标悬停在图片上时,将缩放比例改为1或原来的比例。 示例代码: ```html <style> .img-zoom { transition: transform .2s; } .img-zoom:hover { transform: scale(1.2); } </style> <img src="image.jpg" class="img-zoom"> ``` 2. 使用JavaScript和CSS 通过JavaScript来改变图片的样式,实现图片放大效果。当鼠标悬停在图片上时,将图片的宽高增加一定比例,当鼠标移开时,将图片宽高恢复到原来的大小。 示例代码: ```html <style> .img-zoom { transition: width .2s, height .2s; } </style> <img src="image.jpg" class="img-zoom" onmouseover="zoomIn(this)" onmouseout="zoomOut(this)"> <script> function zoomIn(img) { img.style.width = (img.clientWidth * 1.2) + "px"; img.style.height = (img.clientHeight * 1.2) + "px"; } function zoomOut(img) { img.style.width = ""; img.style.height = ""; } </script> ``` 3. 使用jQuery插件 可以使用一些开源的jQuery插件来实现图片放大效果,比如zoom.js、fancybox等。 使用zoom.js实现图片放大效果的示例代码: ```html <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-zoom/1.7.21/jquery.zoom.min.js"></script> <img src="image.jpg" data-zoom-image="image-large.jpg"> <script> $('img').zoom(); </script> ``` 以上是实现鼠标悬停图片放大的几种方式,可以根据实际需求选择适合的方法。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值