ppms-uni-vue3-huertian/src/components/TabBar.vue
HoshinoSuzumi 34222f94d8 feat: 添加pinia状态管理库和Tabbar组件
添加pinia状态管理库和Tabbar组件,以支持应用的状态管理和底部导航栏功能。
2024-09-15 02:43:15 +08:00

59 lines
1.2 KiB
Vue

<script lang="ts" setup>
import { ref } from 'vue';
import { useRouter, useRoute } from 'uni-mini-router'
import { onMounted, computed, watch } from 'vue';
const props = defineProps({
currentName: {
type: String,
default: 'home'
}
})
const route = useRoute()
const router = useRouter()
const activeTab = ref('home')
onMounted(() => {
activeTab.value = props.currentName
})
watch(activeTab, (val) => {
router.pushTab({ name: val })
})
const nameLabelIconMap = {
home: {
title: '进度查看',
icon: 'dashboard'
},
progress: {
title: '进度管理',
icon: 'transfer'
},
my: {
title: '我的',
icon: 'user'
}
}
const tabList = computed(() => router.routes.map((route: { name: keyof typeof nameLabelIconMap }) => {
return {
name: route.name,
title: nameLabelIconMap[route.name].title,
icon: nameLabelIconMap[route.name].icon
}
}))
</script>
<template>
<div>
<wd-tabbar v-model="activeTab" fixed safe-area-inset-bottom bordered placeholder>
<wd-tabbar-item v-for="(tab, i) in tabList" :name="tab.name" :title="tab.title" :icon="tab.icon" :key="i" />
</wd-tabbar>
</div>
</template>
<style scoped></style>