jQuery手风琴图片轮播(源码+注释)

之前在写js轮播图的时候,没有说手风琴式的轮播图,今天借着jQuery代码少的优势,介绍jQuery下的手风琴轮播图

首先看看实现效果:(图片来自百度)

基本原理:利用float:left来布局,通过改变图片的宽来实现手风琴效果

 

代码及简单注释如下(因为过多的注释会影响记忆和独立思考,所以今后将注释关键点)

jquery代码(3.3.1版):



$(function () {
    // 鼠标离开事件(所有的li的宽变为默认值,恢复原样)
    $('.menu').bind('mouseleave', function () {
        $(this).children('li').each(function () {
            // 两种方法判断如何让恢复原样,第一种需要在变长的同时添加一个属性用来判断当前变长的那个li
            // 第二种简单粗暴,直接找到不为初值li,变为初值即可(注意css值为带px,需转化)
            // console.log($(this).css("width"));
             if(parseInt($(this).css(
  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jQuery手风琴图片切换是一种常用的网页图片效果,可以让网页内容更加生动,增强用户体验。手风琴效果是指在图片时,当前图片会被放大,其他图片则会被压缩。以下是该效果的实现步骤: 1. HTML结构:创建一个包含所有图片的容器和一个包含所有小圆点的容器。 2. CSS样式:为容器和小圆点添加样式,设置图片的宽度、高度和位置。 3. JavaScript代码:实现图片的逻辑。通过jQuery获取容器和小圆点,为小圆点添加点击事件,点击后切换到对应的图片,并给当前图片添加类名,其他图片则移除类名,实现手风琴效果。 以下是一个示例代码: HTML: ``` <div class="slider"> <div class="slider-wrapper"> <img src="img1.jpg" alt=""> <img src="img2.jpg" alt=""> <img src="img3.jpg" alt=""> </div> <div class="dots"> <span></span> <span></span> <span></span> </div> </div> ``` CSS: ``` .slider { width: 100%; height: 500px; position: relative; } .slider-wrapper { width: 100%; height: 100%; position: relative; } .slider-wrapper img { width: 100%; height: 100%; position: absolute; top: 0; left: 0; transition: all 0.5s ease-in-out; } .slider-wrapper img.active { transform: scale(1.2); } .dots { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); } .dots span { display: inline-block; width: 10px; height: 10px; margin-right: 10px; background-color: #ccc; border-radius: 50%; cursor: pointer; } .dots span.active { background-color: #f00; } ``` JavaScript: ``` $(function(){ var $slider = $('.slider'), $wrapper = $('.slider-wrapper'), $imgs = $('.slider-wrapper img'), $dots = $('.dots span'), len = $imgs.length, index = 0; // 初始化 $imgs.eq(0).addClass('active'); $dots.eq(0).addClass('active'); // 点击事件 $dots.on('click', function(){ var idx = $(this).index(); if(idx !== index){ $imgs.eq(index).removeClass('active'); $dots.eq(index).removeClass('active'); $imgs.eq(idx).addClass('active'); $dots.eq(idx).addClass('active'); index = idx; } }); }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值