You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
2.1 KiB
63 lines
2.1 KiB
<template> |
|
<PageWrapper |
|
:title="`用户` + userId + `的资料`" |
|
content="这是用户资料详情页面。本页面仅用于演示相同路由在tab中打开多个页面并且显示不同的数据" |
|
contentBackground |
|
@back="goBack" |
|
> |
|
<template #extra> |
|
<a-button type="primary" danger> 禁用账号 </a-button> |
|
<a-button type="primary"> 修改密码 </a-button> |
|
</template> |
|
<template #footer> |
|
<a-tabs default-active-key="detail" v-model:activeKey="currentKey"> |
|
<a-tab-pane key="detail" tab="用户资料" /> |
|
<a-tab-pane key="logs" tab="操作日志" /> |
|
</a-tabs> |
|
</template> |
|
<div class="pt-4 m-4 desc-wrap"> |
|
<template v-if="currentKey == 'detail'"> |
|
<div v-for="i in 10" :key="i">这是用户{{ userId }}资料Tab</div> |
|
</template> |
|
<template v-if="currentKey == 'logs'"> |
|
<div v-for="i in 10" :key="i">这是用户{{ userId }}操作日志Tab</div> |
|
</template> |
|
</div> |
|
</PageWrapper> |
|
</template> |
|
|
|
<script> |
|
import { defineComponent, ref } from 'vue'; |
|
import { useRoute } from 'vue-router'; |
|
import { PageWrapper } from '/@/components/Page'; |
|
import { useGo } from '/@/hooks/web/usePage'; |
|
import { useTabs } from '/@/hooks/web/useTabs'; |
|
import { Tabs } from 'ant-design-vue'; |
|
|
|
export default defineComponent({ |
|
name: 'AccountDetail', |
|
components: { PageWrapper, ATabs: Tabs, ATabPane: Tabs.TabPane }, |
|
setup() { |
|
const route = useRoute(); |
|
const go = useGo(); |
|
// 此处可以得到用户ID |
|
const userId = ref(route.params?.id); |
|
const currentKey = ref('detail'); |
|
const { setTitle } = useTabs(); |
|
// TODO |
|
// 本页代码仅作演示,实际应当通过userId从接口获得用户的相关资料 |
|
|
|
// 设置Tab的标题(不会影响页面标题) |
|
setTitle('详情:用户' + userId.value); |
|
|
|
// 页面左侧点击返回链接时的操作 |
|
function goBack() { |
|
// 本例的效果时点击返回始终跳转到账号列表页,实际应用时可返回上一页 |
|
go('/system/account'); |
|
} |
|
return { userId, currentKey, goBack }; |
|
}, |
|
}); |
|
</script> |
|
|
|
<style></style>
|
|
|