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 是什么类型。

相关推荐
Forever7_11 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
不会敲代码111 小时前
前端组件化样式隔离实战:React CSS Modules、styled-components 与 Vue scoped 对比
css·vue.js·react.js
Angelial11 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js
SuperEugene13 小时前
Vue状态管理扫盲篇:如何设计一个合理的全局状态树 | 用户、权限、字典、布局配置
前端·vue.js·面试
阿懂在掘金14 小时前
defineModel 是进步还是边界陷阱?双数据源组件的选择逻辑
vue.js·源码阅读
李剑一14 小时前
要闹哪样?又出现了一款新的格式化插件,尤雨溪力荐,速度提升了惊人的45倍!
前端·vue.js
阿虎儿14 小时前
React Context 详解:从入门到性能优化
前端·vue.js·react.js
滕青山17 小时前
文本行过滤/筛选 在线工具核心JS实现
前端·javascript·vue.js
时光不负努力17 小时前
ts+vue3开发规范
vue.js·typescript
梦想CAD控件18 小时前
在线CAD开发包结构与功能说明
前端·javascript·vue.js