components.d.ts声明组件类型的作用

全局注册组件的代码,index.ts

c 复制代码
import LayoutBasicPage from './layout/basic-page'const components = [
 
  LayoutBasicPage,

]const install = (app: App) => {
  for (const component of components) {
    // 注意全局组件必须要有name属性
    app.component(component.name, component)
  }
}

这时跟index.ts新建一个同个级别的components.d.ts

c 复制代码
import '@vue/runtime-core'

declare module '@vue/runtime-core' {
  // GlobalComponents for Volar
  export interface GlobalComponents {
    LayoutBasicPage: typeof import('./layout/basic-page')['default']
  }
}

因为 这两段代码作用完全不同,且互不替代的

文件 运行时用? 给谁用? 目的
index.ts 会打包进最终 JS Vue 运行时 真正注册全局组件,让浏览器能渲染
components.d.ts 编译阶段就被删除 TypeScript / Volar 告诉 TS「模板里写 时是合法组件,并提供类型提示」

总结:运行时注册 ≠ 编译时类型

你在 index.ts 里用 app.component(component.name, component) 把组件注册到 Vue 运行时------浏览器里可以正常渲染。

例如:

c 复制代码
<LayoutBasicPage title="xxx" />

TypeScript 在编译阶段并不知道你运行过这段代码,因此当你在模板里写时,它会报错:

❗ Cannot find name 'LayoutBasicPage'.

也无法提示 title 是什么类型。

相关推荐
还有多久拿退休金3 小时前
我用 Three.js 造了个 3D 漫步世界,角色走路像喝醉了——以及我是怎么修好的
前端·vue.js
LJA648443 小时前
为什么 AI 时代更需要配置化组件库
vue.js
弹简特7 小时前
【Vue3速成】01-npm+vue初体验+vite构建vue工程化
vue.js·arcgis·npm
摸鱼小李上线了8 小时前
vue项目页面添加水印实现方法
前端·javascript·vue.js
i220818 Faiz Ul9 小时前
智慧养老平台|基于SprinBoot+vue的智慧养老平台系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·智慧养老平台
Lkstar9 小时前
Pinia 进阶:Setup Store、插件系统与状态持久化,一篇全搞懂
前端·vue.js
Nikluas9 小时前
彻底搞懂 Vue 运行时的四大核心谜题:Render、Effect、Diff 算法与 Block Tree 演进
vue.js·面试
Aolith9 小时前
手机端刷新总是 404?你需要知道 SPA Fallback 规则
前端·vue.js
zyl837219 小时前
RDKit.js + Vue3快速上手
javascript·vue.js·ecmascript
木易 士心10 小时前
Vue 事件总线(EventBus)详解
javascript·vue.js