微信小程序实现tabs选项卡

微信内部很多组件都已经封装好了,但是却没有tab选项卡的组件,选项卡还是很常用的,我们主要通过微信内置组件根据一些属性来进行切换达到我们的需求

下面是一个简单的效果

wxml

<view class="swiper-tab">
    <view class="swiper-tab-list {{currentTab==0 ? 'on' : ''}}" data-current="0" bindtap="tabNav">隆胸</view>
    <view class="swiper-tab-list {{currentTab==1 ? 'on' : ''}}" data-current="1" bindtap="tabNav">纹眉</view>
    <view class="swiper-tab-list {{currentTab==2 ? 'on' : ''}}" data-current="2" bindtap="tabNav">双眼皮</view>
    <view class="swiper-tab-list {{currentTab==3 ? 'on' : ''}}" data-current="3" bindtap="tabNav">闪现</view>
</view>
<swiper current="{{currentTab}}" duration="1000"  >
    <swiper-item><view>。。。隆胸。。。。</view></swiper-item>
    <swiper-item><view>。。。纹眉。。。。</view></swiper-item>
    <swiper-item><view>。。。双眼皮。。。</view></swiper-item>
    <swiper-item><view>。。。闪现。。。</view></swiper-item>
</swiper>

js

data: {
    isShow: true,
    currentTab: 0,
  },
  tabNav: function (e) {
    console.log(e.target.dataset.current, 111, this.data.currentTab)
    if (this.data.currentTab === e.target.dataset.current) {
      return false;
    } else {
      var showMode = e.target.dataset.current == 0;
      this.setData({
        currentTab: e.target.dataset.current,
        isShow: showMode
      })
    }
  },

css

/* 下面是tobar */
.swiper-tab {
  width: 100%;
  text-align: center;
  line-height: 80rpx;
  background-color:white;
}
.swiper-tab-list {
  font-size: 30rpx;
  display: inline-block;
  width: 25%;
  color: #777;
  border-bottom: 0rpx;
}
.on {
  color: #da7c0c;
  border-bottom: 2rpx solid #da7c0c;
}
.swiper-box {
  display: block;
  height: 100%;
  width: 100%;
  overflow: hidden;
}
.swiper-box view {
  text-align: center;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在微信小程序实现选项卡tabs)效果,可以使用小程序的 `scroll-view` 组件和 `swiper` 组件。 使用 `scroll-view` 组件可以实现横向滚动的效果,而 `swiper` 组件可以实现左右滑动的效果。可以将 `swiper` 组件放在 `scroll-view` 组件中,这样就可以实现选项卡的效果了。 具体实现步骤如下: 1. 在 `wxml` 文件中定义一个 `scroll-view` 组件,并设置 `scroll-x` 属性为 true,表示横向滚动。 ``` <scroll-view class="tab-bar" scroll-x="{{true}}"> <!-- 这里放置选项卡的内容 --> </scroll-view> ``` 2. 在 `scroll-view` 组件中放置 `swiper` 组件,设置 `current` 属性为当前选中的选项卡索引,可以通过 `bindchange` 事件获取用户点击的选项卡索引。 ``` <scroll-view class="tab-bar" scroll-x="{{true}}"> <swiper current="{{current}}" bindchange="swiperChange"> <swiper-item>选项卡1</swiper-item> <swiper-item>选项卡2</swiper-item> <swiper-item>选项卡3</swiper-item> </swiper> </scroll-view> ``` 3. 在 `js` 文件中定义 `swiperChange` 方法,获取用户点击的选项卡索引,并更新 `current` 变量的值,以便在页面中显示当前选中的选项卡。 ``` Page({ data: { current: 0, // 当前选中的选项卡索引 }, swiperChange: function(e) { // 获取用户点击的选项卡索引 var index = e.detail.current; // 更新当前选中的选项卡索引 this.setData({ current: index, }); }, }); ``` 4. 根据当前选中的选项卡索引,动态显示对应的内容。 ``` <swiper-item> <!-- 这里放置选项卡1的内容 --> </swiper-item> <swiper-item> <!-- 这里放置选项卡2的内容 --> </swiper-item> <swiper-item> <!-- 这里放置选项卡3的内容 --> </swiper-item> ``` 以上就是在微信小程序实现选项卡效果的基本步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值