小程序的tab切换事件

index.wxml代码

<view class="tab-left" > 
  <view class="{{tabArr.curHdIndex=='0'? 'active' : ''}}" id="1"  data-id="1" bindtap="tab">tab-hd01</view> 
  <view class="{{tabArr.curHdIndex=='1'? 'active' : ''}}" id="2"  data-id="2" bindtap="tab">tab-hd02</view> 
  <view class="{{tabArr.curHdIndex=='2'? 'active' : ''}}" id="3"  data-id="3" bindtap="tab">tab-hd03</view> 
  <view class="{{tabArr.curHdIndex=='3'? 'active' : ''}}" id="4"  data-id="4" bindtap="tab">tab-hd04</view> 
</view> 
 
<view class="tab-right"> 
  <view class="right-item {{tabArr.curBdIndex=='0'? 'active' : ''}}">tab-bd01</view> 
  <view class="right-item {{tabArr.curBdIndex=='1'? 'active' : ''}}">tab-bd02</view> 
  <view class="right-item {{tabArr.curBdIndex=='2'? 'active' : ''}}">tab-bd03</view> 
  <view class="right-item {{tabArr.curBdIndex=='3'? 'active' : ''}}">tab-bd04</view> 
</view> 

index.wxss代码

.tab-left .active{color: #ff0000}
.tab-right .right-item{display: none}
.tab-right .right-item.active{display: block}

 

index.js代码

Page({
  data:{

    // tab 切换
    tabArr: {
      curHdIndex: 0,
      curBdIndex: 0
    }, 

  },
  //tab切换
  tab: function (e) {
    //var dataId = e.currentTarget.dataset.id;
    var dataId = e.currentTarget.id;
    var obj = {};
    obj.curHdIndex = dataId;
    obj.curBdIndex = dataId;
    this.setData({
      tabArr: obj
    })
    //console.log(e);
  },  
    
})

 

参数传递

在view上绑定id和data-id 都可以传递两个参数,然后用bindtap绑定事件,就可以传递两个参数值

获取参数

用tab:function(e){}可以获取参数,可以console.log(e) 打印出来。用

var dataId = e.currentTarget.dataset.id;
var dataId = e.currentTarget.id;

就可以获取到两个不同的id参数

 

剩下的就可以为所欲为了

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信小程序中的TabBar是用于展示小程序的主要入口和导航栏,用户可以通过它在不同功能模块之间进行切换TabBar通常位于小程序底部,包含固定数量的选项卡,每个选项卡对应小程序的一个页面或功能。 以下是TabBar的基本使用和切换方法: 1. **配置TabBar**: 在`app.json`文件中,需要配置TabBar的项,包括标签名称、路径(对应的小程序页面路径)和图标等。每个TabBar项可以关联一个或多个页面。 ```json { "tabBar": { "color": "#666666", "selectedColor": "#007aff", "list": [ { "pagePath": "pages/index/index", "text": "首页", "iconPath": "path/to/icon.png" }, // 添加其他TabBar项... ] } } ``` 2. **页面跳转**: 在对应的页面内部,可以使用`wx.navigateTo`、`wx.reLaunch`、`wx.switchTab`等API来实现页面间的切换。`wx.switchTab`用于在已存在的TabBar项中切换页面。 ```javascript wx.switchTab({ url: 'pages/second/second' // 要切换到的页面路径 }) ``` 3. **动态显示与隐藏**: 可以根据业务逻辑动态设置TabBar的显示状态,比如某些功能在特定条件下不显示在TabBar上。 4. **监听事件**: TabBar支持自定义事件,可以通过`onTabItemTap`事件监听用户点击某个TabBar项。 5. **设置默认页**: 在`options.json`中可以设置默认加载的第一个页面,也可以在启动时通过`Page({})`配置。 ```javascript Page({ options: { tabBar: { selectedColor: '#007aff' } } }) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值