小程序自定义tabBar,动态控制tabBar

本文介绍了一种在微信小程序中实现动态底部tabBar的方法,通过自定义组件和模板,可以根据客户类型显示不同的底部菜单,提高了小程序的灵活性和用户体验。

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

最近做项目的时候,突然来了个小特殊的需求,根据客户的类型来动态显示底部的tabBar菜单。当时我就有点小懵逼了,这个不是小程序自带的组件么?还要做成动态?这就有点尴尬了.....
不过也只是一时尴尬而已,然后我就展开了搜索之旅.....然后发现,官方的组件确实没办法做动态,那咋办,如果真的有这个需求那也是得去处理滴呀~然后也看了有一些做到这效果的方法,那就试一下呗。。其实就是自定义个tabBar的模板,以下是实现:

首先,既然是说自定义组件,那是用到template了。那先在Page里新建个template的文件夹,以便放tabBar的组件。

然后新建个tabBar.wxml文件,这里就写下你的tabBar的结构。
<template name="tabBar">    
  <view class="tab-bar" style="color: {{tabBar.color}}; background: {{tarBar.backgroundColor}}; {{tabBar.position=='top'? 'top: 0' : 'bottom: 0'}}; {{tabBar.borderStyle? (tabBar.position=='top'? 'border-bottom: solid 1px '+tabBar.borderStyle + ';' : 'border-top: solid 1px '+tabBar.borderStyle + ';') : ''}}">    
  <block wx:for="{{tabBar.list}}" wx:key="pagePath">    
    <navigator url="{{item.pagePath}}" open-type="redirect" class="{{item.clas}}" style="{{item.active? 'color: '+(item.selectedColor? item.selectedColor : tabBar.selectedColor) : ''}}">    
      <image src="{{item.selectedIconPath}}" wx:if="{{item.active}}" class="img"></image>    
      <image src="{{item.iconPath}}" wx:if="{{!item.active}}" class="img"></image>  
      <text class='tabbar_text'>{{item.text}}</text>    
    </navigator>    
    </block>  
    <view class="clear"></view>    
  </view>    
</template>

下面是tabBar所需要用到的样式,我这里就直接写在全局app.wxss了。

.menu-item{  
  width: 32%;  
  float: left;  
  text-align: center;  
  padding-top: 8px;  
}  
.menu-item2{  
  width: 24%;  
  float: left;  
  text-align: center;  
  padding-top: 8px;  
}  
.img{  
  width: 30rpx;  
  height: 30rpx;  
  display: block;  
  margin:auto;  
}  
.clear{  
  clear: both;  
}  
.tab-bar{  
  position: fixed;  
  width: 100%;  
  padding: 0px 2%;  
}  
.tabbar_text{
  font-size: 28rpx
}

然后接下来是js的部分,由于是底部的导航,那肯定是不止一个页面用到的,那这里就可以写在全局的app.js里面方便使用。这里我写了两种tabBar的模板,分别对应来显示

//app.js
App({
  onLaunch: function () {
    // // 展示本地存储能力
    // var logs = wx.getStorageSync('logs') || []
    // logs.unshift(Date.now())
    // wx.setStorageSync('logs', logs)

  },
  //第一种状态的底部  
  editTabBar: function () {
    var _curPageArr = getCurrentPages();
    var _curPage = _curPageArr[_curPageArr.length - 1];
    var _pagePath = _curPage.__route__;
    if (_pagePath.indexOf('/') != 0) {
      _pagePath = '/' + _pagePath;
    }
    var tabBar = this.globalData.tabBar;
    for (var i = 0; i < tabBar.list.length; i++) {
      tabBar.list[i].active = false;
      if (tabBar.list[i].pagePath == _pagePath) {
        tabBar.list[i].active = true;//根据页面地址设置当前页面状态    
      }
    }
    _curPage.setData({
      tabBar: tabBar
    });
  },
  //第二种状态的底部  
  editTabBar2: function () {
    var _curPageArr = getCurrentPages();
    var _curPage = _curPageArr[_curPageArr.length - 1];
    var _pagePath = _curPage.__route__;
    if (_pagePath.indexOf('/') != 0) {
      _pagePath = '/' + _pagePath;
    }
    var tabBar = this.globalData.tabBar2;
    for (var i = 0; i < tabBar.list.length; i++) {
      tabBar.list[i].active = false;
      if (tabBar.list[i].pagePath == _pagePath) {
        tabBar.list[i].active = true;//根据页面地址设置当前页面状态    
      }
    }
    _curPage.setData({
      tabBar: tabBar
    });
  },  
  globalData: {
    userInfo: null,
    pop:2,
    num:0,
    tabBar: {
      "color": "#9E9E9E",
      "selectedColor": "#f00",
      "backgroundColor": "#fff",
      "borderStyle": "#ccc",
      "list": [
        {
          "pagePath": "/pages/index/index",
          "text": "首页",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "clas": "menu-item",
          "selectedColor": "#4665f9",
          active: true
        },
        {
          "pagePath": "/pages/log/index",
          "text": "日志",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item",
          active: false
        },
        {
          "pagePath": "/pages/my/index",
          "text": "我的",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item",
          active: false
        }
      ],
      "position": "bottom"
    },
    tabBar2: {
      "color": "#9E9E9E",
      "selectedColor": "#f00",
      "backgroundColor": "#fff",
      "borderStyle": "#ccc",
      "list": [
        {
          "pagePath": "/pages/index/index",
          "text": "首页",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "clas": "menu-item2",
          "selectedColor": "#4665f9",
          active: true
        },
        {
          "pagePath": "/pages/log/index",
          "text": "日志",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item2",
          active: false
        },
        {
          "pagePath": "/pages/my/index",
          "text": "我的",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item2",
          active: false
        },
        {
          "pagePath": "/pages/new/index",
          "text": "新的",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item2",
          active: false
        }
      ],
      "position": "bottom"
    }
  }
})

然后在需要用到这个组件的页面上直接调用。比如这里的index页面。

<!--index.wxml-->
<import src="../template/tabbar.wxml"/>
首页
<template is="tabBar" data="{{tabBar:tabBar}}"></template>

然后去index.js里面调用tabBar

然后下面是效果图。




链接:https://www.jianshu.com/p/55d54564ec95

转载于:https://www.cnblogs.com/bing0709/p/10551008.html

### 实现微信小程序中的动态 TabBar #### 创建 `tab-service.js` 文件 为了使 TabBar 的数据可以被全局访问,在 utils 目录中创建名为 `tab-service.js` 的文件来存储全局的数据以及操作这些数据的方法[^1]。 ```javascript // utils/tab-service.js const tabsData = [ { pagePath: "page/home", text: "首页" }, { pagePath: "page/user", text: "我的" } ]; export function getTabs() { return new Promise((resolve, reject) => { resolve(tabsData); }); } export function setTabs(newTabs) { tabsData.length = 0; Array.prototype.push.apply(tabsData, newTabs); } ``` #### 配置 app.json 中的导航信息 在项目的根目录找到并编辑 `app.json` 文件,这里需要指定默认显示的 Tab 页面列表。注意,这里的配置项仅作为初始状态设置,实际展示的内容会由自定义组件控制。 ```json { "tabBar": { "list": [], "color": "#9A9A9A", "selectedColor": "#3cc51f" } } ``` #### 构建 Custom Tab Bar 组件 接下来是在项目根目录建立一个新的文件夹叫做 custom-tab-bar 并在其内部构建 WXML、JS 和 WXSS 文件用于渲染自定义底部标签栏。 ##### 编写 Component 结构 (WXML) ```html <!-- custom-tab-bar/index.wxml --> <view class="container"> <block wx:for="{{tabs}}" wx:key="uniqueKey"> <navigator url="{{item.pagePath}}" open-type='switchTab' hover-class="none"> <image src="{{item.iconPath}}"></image> <text>{{item.text}}</text> </navigator> </block> </view> ``` ##### 添加交互逻辑 (JS) ```javascript // custom-tab-bar/index.js import {getTabs} from '../../utils/tab-service'; Component({ data: { tabs: [] }, attached(){ this.loadTabs(); }, methods:{ async loadTabs(){ const result = await getTabs(); this.setData({tabs:result}); } } }) ``` ##### 定义样式表 (WXSS) ```css /* custom-tab-bar/index.wxss */ .container { display: flex; justify-content: space-around; align-items: center; height: 50px; /* 可能需要调整此高度以适应设计需求 */ background-color: white; box-shadow: 0 -2px 8px rgba(0, 0, 0, .1); } .navigator { padding-top: 4rpx; } ``` ##### 注册组件 (JSON) ```json { "component": true, "usingComponents": {} } ``` #### 登录页面获取用户角色 当用户成功登录后,可以根据用户的权限等级或其他条件决定要加载哪些 Tabs 到 TabService 当中去。 ```javascript // pages/login/index.js Page({ onLoad(options){ // 假设这是从服务器端接收到的角色信息 let roleInfo = {"role":"admin"}; if(roleInfo.role === 'admin'){ import('../../utils/tab-service').then(({setTabs})=>{ setTabs([ { pagePath: "/page/dashboard", iconPath:"/static/images/icon_dashboard.png", text: "仪表盘"}, { pagePath: "/page/settings", iconPath:"/static/images/icon_settings.png", text: "设置"} ]); }) }else{ // 对于其他类型的用户... } } }) ``` #### 设置页面标题以便识别 TabBar 切换 对于每一个具体的功能页(比如 home 或者 user),可以在各自的 index.json 文件里加入 `"navigationBarTitleText"` 字段帮助区分当前处于哪个选项卡之下[^3]。 ```json { "navigationBarTitleText": "首页" } ``` 通过上述步骤就可以实现在微信小程序内根据不同的业务场景或是用户身份动态改变 TabBar 显示内容的效果了。值得注意的是,所有涉及到页面跳转的地方都应当遵循官方文档的要求确保路径正确无误[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值