本文主要介绍如何基于已有的组件(好比微信小程序的swiper,还有咱们平时h5用的比较多的swiper.js等),实现一个滑块样式的指示面板。demo基于小程序,可是逻辑通用。html
最近要作一个新的小程序,在首页部分有一个swiper模块,由于设计同窗的出色发挥😭,让我在枯燥的开发中获得了些许快乐。他们将swiper中指示面板中的点,改为了一个滑块,说实话,老老实实整成一排点
它不香么,哈哈哈哈。可是我宠他~小程序
总体来看很简单。主要是下边的滑块须要花一些功夫。整理需求以后须要实现的功能点以下:微信小程序
- 滑块须要有一个天然的滑动效果。
- 滑块须要跟着滑动方向滑动。
通过整理,实现方案以下:微信
- 在滑动swiper的content的时候,咱们能够获取当前页面的
curPage
(通常状况下组件都会提供当前页),接着咱们能够在滑动结束以后设置上一个页面的prePage
,这个prePage其实就是本次的curPage。经过这个page咱们能够获得滑块滑动的起始位置以及结束位置。- 滑动咱们能够经过
transform
来实现。- 由于用了
transform
,因此咱们须要小程序支持自定义style,但目前来看小程序提供了一套this.animate
的方法。
首先咱们须要使用swiper的change事件,代码以下:markdown
<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,也就是咱们的滑块区域,代码以下:ide
<view class="dot">
<view class="dot-bar" style="width: {{dotBarWidth}}rpx"></view>
</view>
复制代码
这其中须要给咱们的滑块一个初始化的大小,否则滑动以后会有一个宽度变换的抖动,也就是dotBarWidth
。
这个滑块的大小是基于滑道的长度,以及swiper-item
的数量来计算的。这样子获得宽度以后咱们只要偏移滑块宽度的倍数便可。ui
let dotWidth = 100;
let dotBarWidth = Math.round(dotWidth/popular_zone_list.length);
复制代码
模板已经写完了,那咱们就开始写change的事件,代码以下:this
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操做便可。
复制代码
到此功能已经实现了,是否是发现这个功能仍是很简单的挺不错的😒。spa
说实话,在实现的过程当中,我有一些比较智障的行为,和当时的状态有关吧,不知怎么就过于关注在如何判断滑块是左滑仍是右滑,致使绕了个路。可是其实基于结果去考虑发现,咱们只要计算起始和结束位置便可,左滑一定是开始位置大于结束位置的。但愿以上方案能给你们一些参考吧~🎉🎉🎉设计