html手机移动端轮播器,原生js实现移动端Touch轮播图的方法步骤

Touch 轮播图

touch轮播图其实就是通过手指的滑动,来左右切换轮播图,下面我们通过一个案例,来实现下。

1. html 结构

结构上,还是用ul、li来存放轮播图片,ol、li来存放轮播小圆点:

3561c8b7de099a6e9b1eb2cef840ad68.png

2. 样式初始化

html的一些标签,都会有一些默认样式,比如body标签默认是有一个边距的,为了不影响美观,我们需要清除掉。

/* 清除标签默认边距 */

body,ul,li,ol,img {

margin: 0;

padding: 0;

}

/* 清除 ul 等标签前面的“小圆点” */

ul,li,ol {

list-style-type: none;

}

/* 图片自适应 */

img {

width: 100%;

height: auto;

border: none;

/* ie8 */

display: block;

-ms-interpolation-mode: bicubic; /*为了照顾ie图片缩放失真*/

}

1b0376c28c73b1bcf9a94e535f187b21.png

3. 添加样式

在前面讲特效的时候,我们说过如何使用原生js实现移一个轮播图的概念,但是当时的方式是通过li浮动,这里给大家介绍一种新的方——定位。

思路:

给ul外层的盒子一个相对定位;

这里的ul高度不能写死,它应该是li撑开的高度,但是由于li绝对定位,没办法撑开这个高度,所以这里的ul需要在js里面动态设置高度;

给li设置相对定位,并且left、top都为0,再给li添加一个transform:translateX(300%)属性,目的是初始化显示的图片为空,然后在js里只需要动态设置每个li的translateX值,即可实现轮播;

设置小圆点区域,因为小圆点个数未知,所以ol的宽度也未知,想要让一个未知宽度的盒子水平居中,可以使用absolute定位结合left百分比的方式实现;

给ol下面的li设置一个宽高添加圆角边框属性,并且左浮动,这样就能显示一排空心的小圆点了;

最后,添加一个样式类,里面设置一个背景属性,用来显示当前展示图片对应的小圆点。

/* 轮播图最外层盒子 */

.carousel {

position: relative;

overflow: hidden;

}

.carousel ul {

/* 这个高度需要在JS里面动态添加 */

}

.carousel ul li {

position: absolute;

width: 100%;

left: 0;

top: 0;

/* 使用 transform:translaX(300%) 暂时将 li 移动到屏幕外面去*/

-webkit-transform: translateX(300%);

transform: translateX(300%);

}

/* 小圆点盒子 */

.carousel .points {

/* 未知宽度的盒子,使用 absolute 定位,结合 transform 的方式进行居中 */

position: absolute;

left: 50%;

bottom: 10px;

transform: translateX(-50%);

}

/* 小圆点 */

.carousel .points li {

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML实现手机轮播图可以使用CSS3的动画特性来实现,也可以使用JavaScript库来实现。而在移动端,推荐使用Swiper来实现轮播图。下面分别介绍两种实现方式。 ## HTML实现手机轮播图 ### 使用CSS3动画实现 HTML结构: ```html <div class="slider"> <img src="image1.jpg"> <img src="image2.jpg"> <img src="image3.jpg"> </div> ``` CSS样式: ```css .slider { width: 100%; height: 300px; overflow: hidden; position: relative; } .slider img { width: 100%; height: 100%; position: absolute; left: 0; top: 0; opacity: 0; animation: slide 5s infinite; } @keyframes slide { 0% { opacity: 0; } 20% { opacity: 1; } 80% { opacity: 1; } 100% { opacity: 0; } } .slider img:nth-child(2) { animation-delay: 1s; } .slider img:nth-child(3) { animation-delay: 3s; } ``` 上面的代码会让轮播图中的图片循环轮播,每张图片停留5秒钟,并且使用了CSS3的动画特性来实现。 ### 使用JavaScript库实现 可以使用一些JavaScript库来实现手机端的轮播图,比如Swiper、Slick等。这里以Swiper为例进行介绍。 HTML结构: ```html <div class="swiper-container"> <div class="swiper-wrapper"> <div class="swiper-slide"><img src="image1.jpg"></div> <div class="swiper-slide"><img src="image2.jpg"></div> <div class="swiper-slide"><img src="image3.jpg"></div> </div> </div> ``` CSS样式: ```css .swiper-container { width: 100%; height: 300px; } .swiper-slide img { width: 100%; height: 100%; } ``` JavaScript代码: ```javascript var mySwiper = new Swiper('.swiper-container', { autoplay: { delay: 5000, }, loop: true, pagination: { el: '.swiper-pagination', }, }); ``` 上面的代码会让轮播图中的图片循环轮播,每张图片停留5秒钟,并且使用了Swiper库来实现。 ## Swiper移动端轮播图简单实现 Swiper是一款移动端的JavaScript库,可以很方便地实现轮播图。下面是一个简单的Swiper轮播图实现代码。 HTML结构: ```html <div class="swiper-container"> <div class="swiper-wrapper"> <div class="swiper-slide"><img src="image1.jpg"></div> <div class="swiper-slide"><img src="image2.jpg"></div> <div class="swiper-slide"><img src="image3.jpg"></div> </div> <div class="swiper-pagination"></div> </div> ``` CSS样式: ```css .swiper-container { width: 100%; height: 300px; } .swiper-slide img { width: 100%; height: 100%; } ``` JavaScript代码: ```javascript var mySwiper = new Swiper('.swiper-container', { autoplay: { delay: 5000, }, loop: true, pagination: { el: '.swiper-pagination', }, }); ``` 上面的代码会让轮播图中的图片循环轮播,每张图片停留5秒钟,并且使用了Swiper库来实现

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值