1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- <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>
|