本页导航
article
基于本库开发新组件
AI摘要
本文介绍了基于现有组件库开发新组件的完整流程。主要步骤包括:在指定目录创建新组件并在入口文件注册;在类型声明文件的四个位置添加相应的类型定义;最后更新版本号并完成发布。
注册新组件
在 src/components 目录下创建新组件,然后在入口文件 src/index.ts 中导入并注册该组件。
添加类型声明
在 types/index.d.ts 文件中添加类型声明,需要在四个地方添加
// 1. 导入时的组件类型定义
declare module 'liyao-vue-common' {
export const uploadCos: DefineComponent<{}, {}, any>;
export const uploadLocal: DefineComponent<{}, {}, any>;
export const newComponent: DefineComponent<{}, {}, any>; // 添加新组件类型
export const install: (app: App) => void;
}
// 2. Vue 全局组件类型定义
declare module 'vue' {
export interface GlobalComponents {
uploadCos: DefineComponent<{}, {}, any>;
uploadLocal: DefineComponent<{}, {}, any>;
newComponent: DefineComponent<{}, {}, any>; // 添加全局组件类型
}
}
// 3. 组件文件模块声明
declare module '@/components/Upload/uploadCos.vue' {
const component: DefineComponent<{}, {}, any>;
export default component;
}
declare module '@/components/Upload/uploadLocal.vue' {
const component: DefineComponent<{}, {}, any>;
export default component;
}
// 添加新组件的模块声明
declare module '@/components/Your/NewComponent.vue' {
const component: DefineComponent<{}, {}, any>;
export default component;
}
// 4. 默认导出
declare const _default: {
install: (app: App) => void;
uploadCos: DefineComponent<{}, {}, any>;
uploadLocal: DefineComponent<{}, {}, any>;
newComponent: DefineComponent<{}, {}, any>; // 添加默认导出类型
};
更新版本号并发布:
# 修改 package.json 中的版本号
pnpm pub
最后更新于 2026-02-17 19:41