小程序实现动态tabbar
创始人
2025-05-28 02:36:39

需求是小程序的地步tabbar 要在后台能设置 还要看能改动的尺度,如果不是在小程序里,那么底部tabbar 随便渲染 ,前端无非就是 请求来数据 循环渲染到页面上。类似于后台系统 根据权限请求左侧导航栏一样

但是这样的模式有一个前提是总数是定的 都有对应的名字和路径 , 但在小程序里虽然底部tabbar限定是 5 个 但是 每个都要动态生成  在app.json中 底部导航 list 又要和页面相对应 ,提供的api 不能修改 app.json    也不能用 custom-tab-bar 

最终决定 使用 vant-weapp van-tabbar 组件来实现   app.json 注册一下  使用到的 一些页面 用{{behaviors}}封装下  相互之间的跳转 使用 wx.redirectTo

  { active }}" bind:change="onChange" active-color="#fff" inactive-color="#fff">

  {tabBarList}}" wx:key="index"  style="{{index === active ? 1 : touming}}" >

    

      slot="icon"

      src="{{ item.IconPath }}"

      mode="aspectFit"

      style="width: 26px; height: 26px;"

    />

    

      slot="icon-active"

      src="{{ item.IconPath }}"

      mode="aspectFit"

      style="width: 26px; height: 26px;"

    />

    {{item.text}}

  

  // 点击tabbar 回调onChange(e){if(this.data.active === e.detail) return // 点击当前页面什么也不做let id = this.data.tabBarList[e.detail].id;  // 取到点击那一项的idwx.redirectTo({// 跳转对应路径 传参 id url: this.data.tabBarList[e.detail].pagePath + '?id=' + id})
},

点击后 索引值判断点击的是那一项  来判断 跳转到什么页面 和传入的 初始请求数据的id

tabbar渲染的列表是 进入小程序时请求过来的  然后根据每一项的属性判断 它对应的是哪一个页面

// 进入页面前 请求 底部的导航栏 并且按照需求抽并封装数据
getTabbar(){wx.request({url: 'xxxxxxxx',method: 'POST',data:{storeId:wx.getStorageSync('storeData').id, // 传参门店idstatus:1 // 获取正常显示的},success: res =>{let yuan = res.data.data // 转存元数据let aaa = yuan.map(x =>{// map 出 tabar 的数据return {text:x.moduleName, // 模块名字IconPath:x.iconUrl, // 图标的 urlid:x.moduleId, // 模块 id 根据id切换tabarmoduleStorey:x.moduleStorey, // 模块的层级 最多 3 层isHomePage:x.isHomePage, // 是否是首页moduleStyle:x.moduleStyle, // 显示格式 0图文  1文字sort:x.sort, // 排序}})aaa.forEach(e => {// 首页有标识 isHomePage 直接对应 pages/index 固定对应的页面if(e.isHomePage === 1){e.pagePath="/pages/index/index"// 二级或者三级 文字展现形式的页面  pages/wenzi_tuwen_anli}else if((e.moduleStorey === 2 || e.moduleStorey === 3) && e.moduleStyle === 1){e.pagePath="/pages/wenzi_tuwen_anli/wenzi_tuwen_anli"// 二级图文 对应的页面 /pages/tuwen_tuwen_notab}else if(e.moduleStorey === 2  && e.moduleStyle === 0){e.pagePath="/pages/tuwen_tuwen_notab/tuwen_tuwen_notab"// 一级或者三级 图文 对应的页面 /pages/tuwen_anli}else if(e.moduleStorey === 1  || e.moduleStorey === 3){e.pagePath="/pages/tuwen_anli/tuwen_anli"}})aaa.sort((a,b) => a.sort - b.sort) // 进行排序}});},

  

 

相关内容

热门资讯

教教大家“wepoker德州开... 您好.wepoker德州这款游戏可以开挂的,确实是有挂的,需要了解加微【97762250】很多玩家在...
玩家实测!兴动麻将外挂辅助器脚... 【无需打开直接搜索微信;29290261】 操作使用教程:1.亲,实际上兴动麻将是可以开挂的,确实有...
玩家实测!荣耀麻将外挂辅助器脚... 您好:荣耀麻将这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,...
玩家攻略秘籍壹乐游戏有外挂吗真... 有过。亲爱的,欢迎您访问我们的网站。根据老记者透露的信息,壹乐游戏这款游戏是可以被骗的。果然有诈。不...
玩家实测!浙西雀友外挂辅助器脚... 您好:浙西雀友这款游戏可以开挂,确实是有挂的,需要了解添加微信【29290261很多玩家在这款游戏中...