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.
|
|
|
|
---
|
|
|
|
|
title: 个人资料选项卡
|
|
|
|
|
description: 扩展个人中心的个人资料选项卡 - uc:user:profile:tabs:create
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
此扩展点用于扩展个人中心的个人资料选项卡。
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/46dfc/46dfc86b6a5a53b7cbb2b4043b71dd932ee38c87" alt="个人资料选项卡"
|
|
|
|
|
|
|
|
|
|
## 定义方式
|
|
|
|
|
|
|
|
|
|
```ts
|
|
|
|
|
export default definePlugin({
|
|
|
|
|
extensionPoints: {
|
|
|
|
|
"uc:user:profile:tabs:create": (): UserProfileTab[] | Promise<UserProfileTab[]> => {
|
|
|
|
|
return [
|
|
|
|
|
{
|
|
|
|
|
id: "foo",
|
|
|
|
|
label: "foo",
|
|
|
|
|
component: markRaw(FooComponent),
|
|
|
|
|
priority: 20,
|
|
|
|
|
},
|
|
|
|
|
];
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
```ts title="UserProfileTab"
|
|
|
|
|
export interface UserProfileTab {
|
|
|
|
|
id: string; // 选项卡 ID
|
|
|
|
|
label: string; // 选项卡标题
|
|
|
|
|
component: Raw<Component>; // 选项卡面板组件
|
|
|
|
|
priority: number; // 排序优先级
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
其中,`component` 组件有以下实现要求:
|
|
|
|
|
|
|
|
|
|
1. 组件包含以下 props:
|
|
|
|
|
1. `user:DetailedUser`:当前用户信息。
|