微信小程序模板-分页滑动栏

这篇博客介绍了如何在微信小程序中创建一个分页滑动栏,包括将分页栏与滑动视图绑定、点击分页栏自动滑动以及滑动时分页栏选中样式的自动更新。文章提供了一张功能实现的效果图以及对应的WXML、WXSS和JS代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

功能:
1.分页栏与滑动视图绑定
2.点击分页栏自动滑动到对应视图
3.滑动的到视图对应分页栏自动显示选中样式
效果图
这里写图片描述

上代码
wxml

<view class="tapNav">
  <view class="{{tabArr.tabCurrentIndex==0?'active':''}}" data-index="0" bindtap="veHandle">分页标签1</view>
  <view class="{{tabArr.tabCurrentIndex==1?'active':''}}"  data-index="1" bindtap="veHandle">分页标签2</view>
  <view class="{{tabArr.tabCurrentIndex==2?'active':''}}"  data-index="2" bindtap="veHandle">分页标签3</view>
</view>
<swiper id="swiper" indicator-dots="{{indicatorDots}}"
  autoplay="{{autoplay}}" interval="{{interval}}" duration="{{duration}}" current="{{current}}" bindchange="swiperChange">
  <block wx:for="{{imgUrls}}">
    <swiper-item id="swiper-item">
      <image id="imgae" src="{{item}}" class="slide-image" width="355" height="150"/>
    </swiper-item>
  </block>
</swiper>

wxss

/*
1.横向排列分页标签
2.每个分页标签各占1/3
*/
.tapNav {
  display: flex;
  flex-direction: row;
}
.tapNav view{
  flex:1;
  width:200rpx;
  height:100rpx;
  text-align: center;
  line-height: 100rpx;
  font-family: "微软雅黑";
}
/*选中样式*/
.tapNav .active {
  color:blue;
  border-bottom:4rpx solid mediumseagreen;
}
#swiper {
  margin-top:40rpx;
}
#swiper image{
  width:100%;
}

js

//index.js
//获取应用实例
var app = getApp()
Page({
  data: {
    // 图片地址
    imgUrls: [
      'http://img02.tooopen.com/images/20150928/tooopen_sy_143912755726.jpg',
      'http://img06.tooopen.com/images/20160818/tooopen_sy_175866434296.jpg',
      'http://img06.tooopen.com/images/20160818/tooopen_sy_175833047715.jpg'
    ],
    //是否显示面板指示点
    indicatorDots: true,
    //自动播放
    autoplay: true,
    //切换时间间隔
    interval: 2000,
    //滑动时长
    duration: 1000,
    //存放滑动视图的current
    current:0,
    //分页标签class条件判断的值
    tabArr:{
      tabCurrentIndex:0
    }
  },
  //事件处理函数
  //触摸分页标签触发事件
  veHandle:function(e){
    //每个分页标签都设置了data-index,触摸触发事件获取此数值
    //用此数值替换滑动视图的current
    //用此数值替换分页标签class判断的值
    console.log(e.target.dataset.index)
    var currentIndex = e.target.dataset.index
    this.setData({
      current:currentIndex,
      "tabArr.tabCurrentIndex":currentIndex
    })
  },
  //通过滑块视图的current改变触发事件
  swiperChange:function(e){
    //获取视图滑块当前的current
    //用此数值替换分页标签的current的值
    console.log(e.detail.current)
    var swiperCurrent = e.detail.current;
    this.setData({
      'tabArr.tabCurrentIndex':swiperCurrent
    })
  },
  onLoad: function () {
    console.log('onLoad')
  }
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值