案例效果:实现移动端端轮播图效果

实现移动端端轮播图效果


插件使用:
1.zepto.js
2.touch.js

实现效果

在这里插入图片描述
html部分:

<!-- 结构 -->
    <!-- li*6>a[href=#]>img[src=./images/$.jpg] -->
    <div class="box">
        <ul>
            <!-- 为了无缝连接,我们在图片这里前后增加了2个图片 -->
            <li>
                <a href="#"><img src="./images/6.jpg" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/1.jpg" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/2.jpg" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/3.jpg" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/4.jpg" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/5.jpg" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/6.jpg" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/1.jpg" alt=""></a>
            </li>
        </ul>
    </div>

css部分:

 * {
            margin: 0;
            padding: 0;
        }
        
        ul {
            list-style: none;
        }
        
        .box {
            width: 100%;
            overflow: hidden;
        }
        
        ul {
            /* 把li变成8张之后,需要,把ul的宽度变宽 */
            width: 800%;
            /* transition: all 1s; */
        }
        
        li {
            float: left;
            width: 12.5%;
        }
        
        img {
            width: 100%;
        }

js部分:

//获取DOM
    var box = $(".box");
    var img = $("ul img");
    var ul = $("ul");
    var imgWidth = img.width();

    var index = 1;
    var right = index * imgWidth;
    ul.css("transform", `translateX(-${right}px)`);
    setTimeout(function() {
        ul.css("transition", "all 500ms");
    }, 100);

    //往左滑,坐标在增大
    box.on("swipeLeft", function() {
        index++;
        // if (index == img.length) {
        //     index = 0;
        // }
        var left = index * imgWidth;
        ul.css("transform", `translateX(-${left}px)`);
    });
    //往左滑,坐标在增大
    box.on("swipeRight", function() {
        index--;
        // if (index == -1) {
        //     index = img.length - 1;
        // }
        var right = index * imgWidth;
        ul.css("transform", `translateX(-${right}px)`);
    });

    //过渡结束之后时进行
    ul.on("transitionend", function() {
        //1.判读 index
        //往左面滑(滑倒倒数第一张的时候,其实显示的已经是用户想看的第一张)
        if (index == img.length - 1) {

            index = 1;
            //index修改完毕之后需要重新执行一遍
            var right = index * imgWidth;
            ul.css("transform", `translateX(-${right}px)`);

            //2.取消过渡效果
            ul.css("transition", "none");
            //3.已经判断完毕了,重新打开过渡效果
            //这里设置一个1毫秒的延迟,否则会一起进行
            setTimeout(function() {
                ul.css("transition", "all 500ms");
            }, 1);
        }

        //1.判读 index
        //往右面滑(滑倒index为0的时候,显示的是客户想看的第6张图)
        if (index == 0) {
            //2.取消过渡效果
            ul.css("transition", "none");
            index = img.length - 2;
            //index修改完毕之后需要重新执行一遍
            var left = index * imgWidth;
            ul.css("transform", `translateX(-${left}px)`);
            //延迟开启过渡效果
            setTimeout(function() {
                ul.css("transition", "all 500ms");
            }, 1)
        }
    })

代码目前就分享到这里,欢迎大家有问题积极评论

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值