微信小程序实现滑动切换自定义页码的方法分析
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了微信小程序实现滑动切换自定义页码的方法,结合实例形式分析了微信小程序页码动态切换相关实现技巧与注意事项,需要的朋友可以参考下
本文实例讲述了微信小程序实现滑动切换自定义页码的方法。分享给大家供大家参考,具体如下
效果如下
这里三个图片使用了swiper组件进行轮播,下方的页码数字1、2、3会随着图片的切换变动位置
在微信小程序中我们是无法操作dom的,那么
var div = document.getElementById('id'); div.setAttribute("class", "className");
这种方式实现。
然后我们可以考虑使用hidden或者wx:if
的方式,将三个页码显示的view进行轮流显示/隐藏操作。不知道为什么这种方式只支持一次操作
,使用了display:none
/block
来达到影藏/显示状态的切换,这个display是写在wxml文件中的
<view class="bottomView" > <view class="bottom1" style="display:{{bottomHidden1}}" > <view class="pageCur"> <text class="textPageCur textFont">{{index+1}}-5</text> //index是因为上方采用了<block wx:for="{{itemInfor}}" >显示内容,index从0开始计数便是当前下标 </view> <view class="buttomImg"> <image clss="horImg" mode=" left" src="../img/horizontal.jpg"></image> </view> </view> <view class="bottom2" style="display:{{bottomHidden2}}"> <view class="pageCur"> <text class="textPageCur textFont" > {{index+1}}-5</text> </view> <view class="buttomImg"> <image clss="horImg" mode=" left" src="../img/horizontal.jpg"></image> </view> </view> <view class="bottom3" style="display:{{bottomHidden3}}"> <view class="pageCur"> <text class="textPageCur textFont">{{index+1}}-5</text> </view> <view class="buttomImg"> <image clss="horImg" mode=" left" src="../img/horizontal.jpg"></image> </view> </view> </view>
以上这就是页码显示部分,页码的组成包括一个text和一个image(下方白色横线),这个内容嵌套在<swiper-item></swiper-item>
中
bottomView采用position:fixed
的定位方式固定在底部设置高和宽,bottom3、2、1采用position:absolute
的方式。需要注意的是,如果在bottomView使用了display:flex
,将无法使用position。所以在这一部分未采用flex。上面的文字和图片部分采用的是display:flex
实现的,这种方式比较简单
在swiper中,绑定了bindchange="swiperChange"
方法,用于在页面切换时触发下方页码的变化动作,在js文件中该方法如下
Page({ data: { bottomHidden1:"block", bottomHidden2: "none" , bottomHidden3: "none" , }, swiperChange:function(event){ var currentView=event.detail.current; //此处使用了swiper的bindchange事件带过来的参数current,这个参数从0开始计数,内容为当前页码 var isHidden1 =""; var isHidden2 =""; var isHidden3 =""; switch (currentView) { case 1: isHidden1 = "none"; isHidden2 = "block"; isHidden3 = "none"; break; case 2: isHidden1 = "none"; isHidden2 = "none"; isHidden3 = "block" ; break; case 0: isHidden1 = "block"; isHidden2 = "none"; isHidden3 = "none";; break; } this.setData({ bottomHidden1:isHidden1, bottomHidden2: isHidden2, bottomHidden3: isHidden3 }); },
希望本文所述对大家微信小程序开发有所帮助。
上一篇:bootstrap与pagehelper实现分页效果
下一篇:vue实现分页组件
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南