目录背景目标效果思路实现swiper监听change自定义dot模块change事件中的逻辑写在最后本文主要介绍如何基于已有的组件(比如微信小程序的swiper,还有我们平时h5用的
本文主要介绍如何基于已有的组件(比如微信小程序的swiper,还有我们平时h5用的比较多的swiper.js等),实现一个滑块样式的指示面板。demo基于小程序,但是逻辑通用。
最近要做一个新的小程序,在首页部分有一个swiper模块,因为设计同学的出色发挥😭,让我在枯燥的开发中得到了些许快乐。他们将swiper中指示面板中的点,改成了一个滑块,说实话,老老实实整成一排点它不香么,哈哈哈哈。但是我宠他~
整体来看很简单。主要是下边的滑块需要花一些功夫。整理需求之后需要实现的功能点如下:
经过整理,实现方案如下:
首先我们需要使用swiper的change事件,代码如下:
<swiper
class="hot-content-swiper"
indicator-dots="{{indicatorDots}}"
vertical="{{vertical}}"
bindchange="sliderHandler">
<block wx:for="{{popular_zone_list}}" wx:key="*this">
<swiper-item>
<view class="hot-list">
这个是swiper{{index}}
</view>
</swiper-item>
</block>
</swiper>
其次,我们需要自定dot的DOM,也就是我们的滑块区域,代码如下:
<view class="dot">
<view class="dot-bar" style="width: {{dotBarWidth}}rpx"></view>
</view>
这其中需要给我们的滑块一个初始化的大小,不然滑动之后会有一个宽度变换的抖动,也就是dotBarWidth。
这个滑块的大小是基于滑道的长度,以及swiper-item的数量来计算的。这样子得到宽度之后我们只要偏移滑块宽度的倍数即可。
let dotWidth = 100;
let dotBarWidth = Math.round(dotWidth/popular_zone_list.length);
模板已经写完了,那我们就开始写change的事件,代码如下:
sliderHandler({detail}) {
let curPage = detail.current;
let self = this;
this.animate('.dot-bar', [
{
translateX: self.prePage * 100 + '%',
transformOrigin: 'center',
},
{
translateX: curPage*100 + '%',
transformOrigin: 'center',
},
], 100, function () { //animate的回调
self.prePage = curPage;
self.clearAnimation('.container', {
translateX: true,
transformOrigin: true
});
});
},
// 如果不是小程序,那么this.animate这个换成动态绑定style,或者其他的DOM操作即可。
到此功能已经实现了,是不是发现这个功能还是很简单的挺不错的😒。
说实话,在实现的过程中,我有一些比较智障的行为,和当时的状态有关吧,不知怎么就过于关注在如何判断滑块是左滑还是右滑,导致绕了个路。但是其实基于结果去考虑发现,我们只要计算起始和结束位置即可,左滑必定是开始位置大于结束位置的。希望以上方案能给大家一些参考吧~🎉
到此这篇关于微信小程序swiper-dot中的点如何改成滑块的文章就介绍到这了,更多相关微信小程序swiper-dot点改滑块内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: 微信小程序swiper-dot中的点如何改成滑块详解
本文链接: https://lsjlt.com/news/129653.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-01-12
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0