微信小程序swiper大小调整(微信小程序swiper-dot中的点如何改成滑块详解)
类别:编程学习 浏览量:963
时间:2021-10-16 00:35:56 微信小程序swiper大小调整
微信小程序swiper-dot中的点如何改成滑块详解目录
- 背景
- 目标效果
- 思路
- 实现
- swiper监听change
- 自定义dot模块
- change事件中的逻辑
- 写在最后
本文主要介绍如何基于已有的组件(比如微信小程序的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点改滑块内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- 微信小程序如何请求服务器数据(微信小程序学习笔记之页面配置与路由方式)
- 微信小程序简易计算器制作(微信小程序实现简单计算器功能)
- 微信小程序开发简单计算器(小程序实现计算器功能)
- 微信小程序可以用h5开发不(微信小程序webView嵌入H5的方法实例)
- 微信小程序swiper大小调整(微信小程序swiper-dot中的点如何改成滑块详解)
- 微信小程序的交通码(微信小程序中实现车牌输入功能)
- 微信小程序接口返回数据怎么弄(微信小程序页面返回传值的4种解决方案汇总)
- 微信小程序贪吃蛇大作战(微信小程序实现贪吃蛇游戏)
- 微信小程序日期选择器有星期天(微信小程序 滚动选择器时间日期详解及实例代码)
- 微信小程序苹果部分内容打不开(微信小程序audio组件在ios端无法播放的解决办法)
- 微信小程序计时器(微信小程序实现简单的计算器功能)
- 微信小程序引用模板的函数(微信小程序页面与组件之间信息传递与函数调用)
- 微信小程序获取手机信息(微信小程序获取手机号的踩坑记录)
- 微信小程序css使用技巧(微信小程序 CSS filter滤镜的使用示例详解)
- 微信小程序单选框组件(微信小程序picker多列选择器mode = multiSelector)
- 微信小程序通知验证签名方法(微信小程序实现电子签名)
- 花不语 下 如果重来一次的话,你还会这么选择吗(花不语下如果重来一次的话)
- 城市记忆之上海 最难忘的是老弄堂里的市井味道(城市记忆之上海)
- 太鸡贼了,这老小区轻松搞定了停车问题(这老小区轻松搞定了停车问题)
- 太鸡贼了,这老小区轻松搞定了停车问题(这老小区轻松搞定了停车问题)
- 节日我在岗|警景相融 平安相伴(节日我在岗警景相融)
- 战 疫 时刻 致敬每一位石化大学的 守护者(战疫时刻)
热门推荐
- php怎么弄不重复字符串(PHP中将一个字符串部分字符用星号*替代隐藏的实现代码)
- 怎么查看nginx支持rewrite(nginx里的rewrite跳转的实现)
- css 模块阴影(CSS 曲线阴影实现的示例代码)
- python 的常用工具(Python静态类型检查新工具之pyright 使用指南)
- linq not in 查询
- mysqljoin默认是什么(mysql-joins具体用法说明)
- sql如何合并多个表中的数据(SQL 列不同的表查询结果合并操作)
- canvas宽高技巧(canvas画图被放大且模糊的解决方法)
- cdn网络搭建(使用云服务器搭建网站还有必要使用CDN吗?)
- C#中ICollection介绍
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9