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

 更新时间:2021年07月02日 09:36:08   作者:Winder  
swiper组件是滑块视图容器,这篇文章主要给大家介绍了关于微信小程序swiper-dot中的点如何改成滑块的相关资料,实现以后的效果还是不错的,需要的朋友可以参考下

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

背景

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

目标效果

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

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

思路

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

  • 在滑动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点改滑块内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 轻松实现js弹框显示选项

    轻松实现js弹框显示选项

    这篇文章主要为大家详细介绍了js轻松实现弹框显示选项效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • JavaScript实现表格点击排序的方法

    JavaScript实现表格点击排序的方法

    这篇文章主要介绍了JavaScript实现表格点击排序的方法,可实现点击顶部数据项标题实现对应数据列的排序效果,涉及javascript鼠标事件及数据排序的技巧,需要的朋友可以参考下
    2015-05-05
  • 论Bootstrap3和Foundation5网格系统的异同

    论Bootstrap3和Foundation5网格系统的异同

    这篇文章主要介绍了Bootstrap3和Foundation5网格系统,网格的基本构造,如何构建的,描述它们的主要部件,以及它们对不同屏幕的大小表现出的差异,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • Javascript动态绑定事件的简单实现代码

    Javascript动态绑定事件的简单实现代码

    Javascript事件绑定的方法很多,很灵活。不过,作为比较简单的动态绑定,下面的代码看似正确,但得不到预期的效果。
    2010-12-12
  • 基于JavaScript实现新年贺卡特效

    基于JavaScript实现新年贺卡特效

    本文介绍了一款超级炫酷的2022新年快乐html网页特效,霓虹的城市夜景和绚烂的烟花很是特别,该html页面还有交互效果,点击鼠标就会呈现烟花绽放的特效。需要的可以参考一下
    2022-01-01
  • Postman动态获取返回值过程详解

    Postman动态获取返回值过程详解

    这篇文章主要介绍了Postman动态获取返回值过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • JS中引用百度地图并将百度地图的logo和信息去掉

    JS中引用百度地图并将百度地图的logo和信息去掉

    采用CSS覆盖的方法就可以了,但是官方是不允许这么做的,具体实现如下,感兴趣的朋友可以参考下
    2013-09-09
  • MUI 实现侧滑菜单及其主体部分上下滑动的方法

    MUI 实现侧滑菜单及其主体部分上下滑动的方法

    下面小编就为大家分享一篇MUI 实现侧滑菜单及其主体部分上下滑动的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • 浅析js预加载/延迟加载

    浅析js预加载/延迟加载

    本文主要介绍了js预加载和延时加载2种技术,简单分析了他们的实现方式和优缺点,非常的实用,有需要的朋友参考下
    2014-09-09
  • javascript实现贪吃蛇小游戏

    javascript实现贪吃蛇小游戏

    这篇文章主要为大家详细介绍了javascript实现贪吃蛇小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07

最新评论