pc端控制渲染小程序之自定义tabBar
创始人
2024-03-26 16:13:07
0

需求是这样的:底部的tabBar可以跳转任意页面。

刚开始接到这样的需求,我很难受,原因是:

1.底部导航栏规定了最多5个主页面,可以通过wx.switchTab()进行跳转。
2.规定的主页面还需要在app.json中定义好

这样是不能实现底部tabBar跳转任意页面的。

因此经过时间研究后,得到结果:

自己自定义tabBar组件,不用微信小程序自定义的tabBar组件,然后再需要应该应用的主页面上添加tabBar组件。

//跳转方法
export const jump = function (target,tabSource = false) {console.log("跳转",target)if (!target) returnlet { name, type, id,path,param } = target.jumpswitch (type) {case 'fixed': // 固定页面name = name ? name : typebreakcase 'custom': // 自定义页面是否已配置首页或Tab页,如果已配置则对应跳转let targets = findTab(id)console.log("跳转name",targets)name = targets ? targets.jump.name : target.jump.typebreak}// 储存当前跳转信息// wx.setStorageSync('jump', { name, type, id })console.log("跳转name",name)switch (name) {case 'home':wx.switchTab({url: '/pages/home/page'})breakcase 'customize_one':wx.switchTab({url: '/pages/customize_one/page'})breakcase 'customize_two':wx.switchTab({url: '/pages/customize_two/page'})breakcase 'customize_three':wx.switchTab({url: '/pages/customize_three/page'})breakcase 'customize_four':wx.switchTab({url: '/pages/customize_four/page'})break//自定义页面case 'custom':wx.navigateTo({url: `/subPackages/custom/index?pageId=${id}&&tabSource=${tabSource}`})break//固定页面case 'fixed':wx.navigateTo({url: path,success: function (res) {res.eventChannel.emit('acceptData', {param: param,tabSource:tabSource})},fail(res){console.log("跳转错误",res)console.log("跳转路径报错",path)}})break;}
}

和后台进行探讨后,把页面分成2种:固定页面和自定义页面。
固定页面就是跳转到完全写好的页面
自定义页面是通过pc端控制拖拽得到的页面。
我把固定页面的路径存入了数据库,自定义页面的路径前端控制。
至于app.json中定义的导航list,我全部放了自定义页面,定义了5个自定义主页面

因此如果底部导航栏是需要跳转固定页面,就用wx.navigateTo,如果是跳转自定义页面,就用wx.switchTab.虽然这样有个问题,就是跳转固定页面时候,导航栏会带返回按钮,但是可以通过自定义导航栏实现是否需要返回按钮。

//这个方法是底部导航栏高亮显示的方法,在attached中进行调用
onClickTabBar: function () {let that = this;let length = getCurrentPages().lengthlet pagePath = getCurrentPages()[length - 1].route;that.data.list.forEach((item, i) => {if (item.jump.path === `/${pagePath}`) {that.setData({selected: i})}})}

这样就解决了,相当于在每个主页面中引入了一个底部组件,每个页面中的底部tabBar各部相关,哈哈哈哈哈哈~~~~~~~~~~~

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...