微信小程序swiper-dot中的点如何改成滑块详解

2022-04-15 0 354
目录
  • 背景
  • 目标效果
  • 思路
  • 实现
    • swiper监听change
    • 自定义dot模块
    • change事件中的逻辑
  • 写在最后

    本文主要介绍如何基于已有的组件(比如微信小程序的swiper,还有我们平时h5用的比较多的swiper.js等),实现一个滑块样式的指示面板。demo基于小程序,但是逻辑通用。

    背景

    最近要做一个新的小程序,在首页部分有一个swiper模块,因为设计同学的出色发挥,让我在枯燥的开发中得到了些许快乐。他们将swiper中指示面板中的点,改成了一个滑块,说实话,老老实实整成一排点它不香么,哈哈哈哈。但是我宠他~

    目标效果

    整体来看很简单。主要是下边的滑块需要花一些功夫。整理需求之后需要实现的功能点如下:

    • 滑块需要有一个自然的滑动效果。
    • 滑块需要跟着滑动方向滑动。

    微信小程序swiper-dot中的点如何改成滑块详解

    思路

    经过整理,实现方案如下:

    • 在滑动swiper的content的时候,我们可以获取当前页面的curPage(一般情况下组件都会提供当前页),接着我们可以在滑动结束之后设置上一个页面的prePage,这个prePage其实就是本次的curPage。通过这个page我们可以得到滑块滑动的起始位置以及结束位置。
    • 滑动我们可以通过transform来实现。
    • 因为用了transform,所以我们需要小程序支持自定义style,但目前来看小程序提供了一套this.animate的方法。

    实现

    swiper监听change

    首先我们需要使用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模块

    其次,我们需要自定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事件中的逻辑

    模板已经写完了,那我们就开始写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点改滑块内容请搜索NICE源码以前的文章或继续浏览下面的相关文章希望大家以后多多支持NICE源码!

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 JavaScript 微信小程序swiper-dot中的点如何改成滑块详解 https://www.niceym.com/29441.html