微信小程序自定义底部导航栏

基于vant-weapp的底部导航栏,首先根据vant官网安装vant

https://vant-ui.github.io/vant-weapp/#/quickstart

由于vant的Tabbar 标签栏自带翻页效果,而且不够美观,且小程序最多只支持10个页面栈,点击多了会导致报错

微信小程序自定义底部导航栏_第1张图片

报错如下 

微信小程序自定义底部导航栏_第2张图片

将wx.navigateTo改为wx.redirectTo在反复多点很多次之后依然会报错,所以还得优化

源码文件链接:

https://download.csdn.net/download/qq_48702470/86838097

贴上代码:

wxml:


  {{
    item.text
  }}

 js:

Component({
    properties: {
        navList: {
            type: Array,
            default: () => {
                return [{
                        icon: 'home-o',
                        text: '页面1',
                        url: '/pages/home/home'
                    },
                    {
                        icon: 'search',
                        text: '页面2',
                        url: '/pages/mine/mine'
                    }
                ]
            }
        },
    },
    data: {
        active: 0
    },

    methods: {
        onChange(event) {
            // 当反复点击当前的页面,就不做切换操作了
            if (event.detail !== this.data.active) {
                this.setData({
                    active: event.detail
                });
                wx.switchTab({
                    url: this.data.navList[event.detail].url
                });
            }
            this.triggerEvent('onFooterNavChange', event)
        },

        init() {
            const page = getCurrentPages().pop();
            this.setData({
                active: this.data.navList.findIndex(item => item.url === `/${page.route}`)
            });
        }
    }
});

json:

{
	"component": true,
	"usingComponents": {
		"van-tabbar": "@vant/weapp/tabbar/index",
        "van-tabbar-item": "@vant/weapp/tabbar-item/index"
	}
}

使用方法:

1. 现将组件放入项目根目录的components文件夹下,自定义组件统一放在这里。(可以不用像微信官方案例一样的custom-tab-bar直接放在根目录下,强迫症表示很难受)

微信小程序自定义底部导航栏_第3张图片

2. 然后在app.json中全局设置tabBar的custom属性为true,和其他相关属性

微信官方案例:https://developers.weixin.qq.com/miniprogram/dev/framework/ability/custom-tabbar.html

"tabBar": {
		"custom": true,
		"color": "#000000",
		"selectedColor": "#000000",
		"backgroundColor": "#000000",
		"list": [
			{
                "pagePath": "pages/home/home"
			},
			{
				"pagePath": "pages/mine/mine"
			}
		]
	}

3. 开始使用

在需要使用到该组件的页面wxml中:



在需要使用到该组件的页面js中:

data: {
    footerNavList: [{
            icon: 'home-o',
            text: '首页',
            url: '/pages/home/home'
        },
        {
            icon: 'friends-o',
            text: '我的',
            url: '/pages/mine/mine'
        }
    ],
},

/**
 * 生命周期函数--监听页面显示
 */
onShow() {
   // 通过id获取底部导航栏组件,调用其中的init方法获取当前页面
   let footerNavComp = this.selectComponent('#footer-nav-bar-id');
   // 调用组件中的init方法,重要,若没有这一步,在切换导航页面的时候,底部图标高亮会有问题
   footerNavComp.init()
},

onFooterNavChange(event) {
    // 点击底部导航栏切换后回调
    // console.log('点击底部导航栏', event.detail.detail);
}

最终实现效果:

微信小程序自定义底部导航栏_第4张图片

你可能感兴趣的:(微信小程序,微信小程序,小程序)