移动端html轮播,基于javascript实现移动端轮播图效果

本文实例为大家分享了js实现移动端轮播图效果的具体代码,供大家参考,具体内容如下

插件使用:

1.zepto.js

2.touch.js

实现效果

b25d216470a5aa2e2a3dfc8f1fcd3bda.gif

html部分:

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)

}

})

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值