微信小程序swiper-dot中的点怎么改成滑块

发布时间:2022-04-02 17:01:37 作者:iii
来源:亿速云 阅读:217

这篇文章主要介绍“微信小程序swiper-dot中的点怎么改成滑块”,在日常操作中,相信很多人在微信小程序swiper-dot中的点怎么改成滑块问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”微信小程序swiper-dot中的点怎么改成滑块”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

目标效果

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

微信小程序swiper-dot中的点怎么改成滑块

思路

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

实现

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中的点怎么改成滑块”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

推荐阅读:
  1. 如何在微信小程序中实现点赞、取消点赞功能
  2. 微信小程序实现带刻度尺滑块功能

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

微信小程序 swiper-dot

上一篇:微信小程序audio组件在ios端无法播放怎么解决

下一篇:C++ SOCKET多线程怎么实现聊天小程序

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》