当前位置: 首页 > news >正文

import(‘../views/Login.vue‘), 提示找不到模块或其相应的类型声明;

技术栈:ts+vue3+vite

创建一个 vite-env.d.ts文件

/// <reference types="vite/client" />

declare module '*.vue' {

import type { DefineComponent } from 'vue'

const component: DefineComponent<{}, {}, any>

export default component

}

上面代码用于在 TypeScript 项目中为 .vue 文件提供类型支持

在 TypeScript 中,三斜线指令是一种特殊的注释,用于告诉编译器在编译时包含额外的类型定义文件。

/// <reference types="vite/client" /> 表明当前项目依赖于 vite/client 这个类型定义包。

这是一个 TypeScript 三斜线指令(triple-slash directive)

它告诉 TypeScript 编译器引入 Vite 客户端的类型声明

这样就能获得 Vite 提供的内置类型支持,如导入静态资源(图片、CSS 等)时的类型提示

vite/client 是 Vite 框架提供的类型定义文件,它包含了 Vite 客户端相关的类型信息,比如环境变量类型、导入模块的类型等。通过引入这个类型定义,TypeScript 编译器就能正确识别和处理与 Vite 客户端相关的代码。

declare module 是在 TypeScript 中声明一个模块的语法

declare module '*.vue'

这是 TypeScript 的模块声明语法,用于为没有类型定义的模块提供类型声明

具体来说,它为所有 .vue 文件扩展名的模块声明了类型

在 TypeScript 中,默认不认识 .vue 文件,所以需要这个声明

从 Vue 中导入 DefineComponent 类型

import type { DefineComponent } from 'vue'

从 Vue 中导入 DefineComponent 类型

使用 import type 表示只导入类型,不会在运行时引入实际代码

声明一个名为 component 的常量,类型为 DefineComponent

const component: DefineComponent<{}, {}, any>

声明一个名为 component 的常量,类型为 DefineComponent

DefineComponent 是 Vue 组件的类型,有三个泛型参数:

-- 第一个 {} 表示组件的 props 类型为空对象

-- 第二个 {} 表示组件的 emits 类型为空对象

-- 第三个 any 表示组件的插槽内容类型为 any(任意类型)

将 component 作为默认导出

export default component

将 component 作为默认导出

这样在导入 .vue 文件时,TypeScript 就知道默认导出的是一个 Vue 组件

这段代码的主要作用是让 TypeScript 能够正确识别和处理 .vue 文件的导入,为 Vue 单文件组件提供类型支持。当你在代码中使用 import xxx from './xxx.vue' 时,TypeScript 编译器就会根据这个声明文件知道导入的是一个 Vue 组件,并提供相应的类型检查

分类: vue, ts

http://www.jsqmd.com/news/120524/

相关文章:

  • 寒潮预警!2025这些国产儿童羽绒服,宝妈必看! - 品牌测评鉴赏家
  • 8 个降AI率工具推荐,继续教育学生必备
  • PPT-三维立体人物效果
  • 9151 NTN 通信关键技术点
  • # 使用 Flutter 构建跨平台应用:入门与实战
  • java农村集体产权管理系统springboot-vue
  • Java毕设项目推荐-基于SpringBoot框架的人事管理系统的设计与实现基于springboot的人力资源管理系统的设计与实现【附源码+文档,调试定制服务】
  • json校验库
  • Java毕设项目推荐-基于springboot宠物中心信息管理系统的设计与实现基于springboot的养宠物指南服务平台系统的设计与实现【附源码+文档,调试定制服务】
  • 约翰·伯格的资产配置理论
  • java动物宠物领养公益网站springboot-vue
  • 六、面向对象
  • 才会把你的寂寞当作契合的灵魂
  • Java毕设选题推荐:基于SpringBoot的演唱会售票系统设计与实现基于springboot的演唱会购票系统的设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 命越算越薄?一张电器说明书给你讲透唯物主义命理观
  • react 用于校验schema的库
  • 9151 NTN 地面网络与卫星网络的无缝切换
  • 计算机Java毕设实战-基于springboot的人力资源管理系统的设计与实现基于springboot的企业人事管理系统的设计与实现员工管理、部【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • Java毕设选题推荐:基于springboot的养宠物指南服务平台系统的设计与实现基于SpringBoot+Vue的宠物健康咨询系统【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 2025年儿童羽绒服选购指南:从专业参数到口碑品牌,这篇帮你全搞懂 - 品牌测评鉴赏家
  • Yii2-Swoole 快速入门
  • 视觉SLAM十四讲(v2)-(4.4.2)例子:详细解释评估轨迹的误差公式
  • 【CVPR2021冠军方案深度解析】基于骨架感知的多模态手语识别系统:从零到一的完整实现指南
  • 儿童近视怎么办?科学防控攻略全解析
  • 2025年儿童羽绒服十大名牌测评:守护成长的温暖之选 - 品牌测评鉴赏家
  • 婴童羽绒服怎么选不踩坑?这5个口碑品牌帮你搞定冬日保暖难题 - 品牌测评鉴赏家
  • 前端vue3框架的快速搭建
  • 青少年羽绒服选购指南:选对温暖战袍,轻松过冬不臃肿 - 品牌测评鉴赏家
  • 9151 NTN 卫星轨道与波束类型
  • 双目相机视差算法原理与算法详细描述,它为什么可以计算每个像素的深度值?