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

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

站在用户的角度思考问题,与客户深入沟通,找到千阳网站设计与千阳网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站制作、成都网站制作、企业官网、英文网站、手机端网站、网站推广、域名与空间、雅安服务器托管、企业邮箱。业务覆盖千阳地区。

目标效果

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

  • 滑块需要有一个自然的滑动效果。

  • 滑块需要跟着滑动方向滑动。

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

思路

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

  • 在滑动swiper的content的时候,我们可以获取当前页面的curPage(一般情况下组件都会提供当前页),接着我们可以在滑动结束之后设置上一个页面的prePage,这个prePage其实就是本次的curPage。通过这个page我们可以得到滑块滑动的起始位置以及结束位置。

  • 滑动我们可以通过transform来实现。

  • 因为用了transform,所以我们需要小程序支持自定义style,但目前来看小程序提供了一套this.animate的方法。

实现

swiper监听change

首先我们需要使用swiper的change事件,代码如下:


 
   
     
       这个是swiper{{index}}
     
   
 

自定义dot模块

其次,我们需要自定dot的DOM,也就是我们的滑块区域,代码如下:


 

这其中需要给我们的滑块一个初始化的大小,不然滑动之后会有一个宽度变换的抖动,也就是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中的点怎么改成滑块
当前链接:http://bzwzjz.com/article/ihohec.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 移动手机网站制作 企业网站设计 温江网站设计 网站建设公司 成都网站建设 盐亭网站设计 手机网站制作 移动网站建设 成都网站建设公司 成都网站建设 网站建设 重庆企业网站建设 手机网站制作 专业网站设计 成都网站建设流程 成都网站设计 温江网站设计 营销型网站建设 手机网站制作 成都网站设计 成都网站设计 成都响应式网站建设