文章目录
- 前言
- 一、uniapp 实现 tabbar
- 二、图标使用网络图片
- 后端返回tabbar信息
- uniapp方式中的setTabBarItem
- 总结
前言
记录uniapp 开发小程序的底部tabbar ,这里讨论的不是自定义tabbar的情况。而是使用wx.setTabBarItem(Object object) 这个api的情况。关于custom 小程序底部tabbar的可以跳过。
一、uniapp 实现 tabbar
实现 tabbar 的简单步骤如下:
- 在 uniapp 项目的
pages.json
文件中,配置tabBar
字段,来定义 tabbar 的样式和内容,例如:
{"tabBar": {"color": "#666","selectedColor": "#f00","backgroundColor": "#fff","borderStyle": "black","list": [{"pagePath": "pages/index/index","text": "首页","iconPath": "static/tabbar/home.png","selectedIconPath": "static/tabbar/home_active.png"},{"pagePath": "pages/cart/cart","text": "购物车","iconPath": "static/tabbar/cart.png","selectedIconPath": "static/tabbar/cart_active.png"},{"pagePath": "pages/user/user","text": "个人中心","iconPath": "static/tabbar/user.png","selectedIconPath": "static/tabbar/user_active.png"}]}
}
-
在
pages
目录下创建对应的三个页面:index
、cart
和user
。 -
在
pages/index
目录下创建index.vue
文件,编写首页的内容。 -
在
pages/cart
目录下创建cart.vue
文件,编写购物车页面的内容。 -
在
pages/user
目录下创建user.vue
文件,编写个人中心页面的内容。 -
在
App.vue
文件中,将tabbar
的内容放在<tabbar>
标签内,例如:
<template><view><router-view></router-view><tabbar></tabbar></view>
</template>
- 在项目的根目录下,创建
components
文件夹,再在该文件夹下创建tabbar.vue
文件,编写 tabbar 的样式和逻辑,例如:
<template><view class="tabbar"><view v-for="(item, index) in tabBar.list" :key="index" class="tabbar-item" @click="switchTab(index)"><image :src="item.selected ? item.selectedIconPath : item.iconPath" class="tabbar-icon"></image><view class="tabbar-text">{{ item.text }}</view></view></view>
</template><script>
export default {data() {return {tabBar: getApp().globalData.tabBar // 从全局数据中获取 tabBar 的配置}},methods: {switchTab(index) {uni.switchTab({url: '/' + this.tabBar.list[index].pagePath})}}
}
</script><style scoped>
.tabbar {display: flex;justify-content: space-between;align-items: center;height: 50px;background-color: #fff;border-top: 1px solid #000;
}.tabbar-item {flex: 1;display: flex;flex-direction: column;align-items: center;justify-content: center;font-size: 12px;color: #666;
}.tabbar-icon {width: 24px;height: 24px;
}.tabbar-text {margin-top: 2px;
}
</style>
- 在
main.js
文件中全局配置 tabBar 的配置,例如:
App({globalData: {tabBar: require('./pages.json').tabBar}
})
这样,就完成了 tabbar 的简单实现过程。tabbar 的样式和逻辑可以根据项目的需求进行自定义修改,tabbar第一个path与pages的path 保持一致。也就是首页路径。
二、图标使用网络图片
那么如果是icon是后端返回网络图片,url的形式。
{"iconPath": "https://files/static/tabbar/home.png","selectedIconPath": "https://files/static/tabbar/home_active.png"
}
注意这个功能要小程序版本的基础库版本在 2.7.0以上。
后端返回tabbar信息
后端返回tabbar信息,已达到可以在后端管理tabbar的图标。即是iconPath,selectedIconPath 这些是支持重置。官方提供了这个apiwx.setTabBarItem(Object object)
uniapp方式中的setTabBarItem
如图在onLauch中加入相关逻辑。获取tabbar信息后,uni.setTabBarItem。
总结
今天的内容就在这里了,本文讨论如何使用uniapp实现基本tabbar功能,接着给出动态设置icon的思路。依赖的api是uni.setTabBarItem。