脚本宝典收集整理的这篇文章主要介绍了微信小程序swiper-dot中的点如何改成滑块详解,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
本文主要介绍如何基于已有的组件(比如微信小程序的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点改滑块内容请搜索脚本宝典以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本宝典!
以上是脚本宝典为你收集整理的微信小程序swiper-dot中的点如何改成滑块详解全部内容,希望文章能够帮你解决微信小程序swiper-dot中的点如何改成滑块详解所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。