发布时间:2023-04-24 文章分类:WEB开发, 电脑百科 投稿人:赵颖 字号: 默认 | | 超大 打印

vscode报错:./APP.vue不是模块

  • 场景复现
  • 情况一、vue3.0+js
  • 情况二、vue3.0+ts
    • 方案一:根目录新建env.d.ts
    • 方案二:根目录新建tsconfig.json

vue3报错提示 找不到模块“/App.vue”或其相应的类型声明

场景复现

在使用 vue3➕vite➕ts 或者 js 搭建前端框架时,在main.ts或者main.js中引入/App.vue报错。报错内容为 /App.vue不是模块。下面我们分vue3+jsvue3+ts两种情况讨论,给出相应的解决方案。

情况一、vue3.0+js

报错显示
vue3+vite在main.ts或者main.js文件中引入/App.vue报错(/App.vue不是模块)
报错原因:javascript只能理解.js文件,无法理解.vue文件。

解决方案根目录新建jsconfig.json

{
    "compilerOptions": {
        "baseUrl": "./",
        "paths": {
            "@/*":[
                "src/*"
            ]
        }
    },
    "exclude": [
        "node_modeules",
        "dist"
    ]
}

此时问题已经解决:👇👇👇
vue3+vite在main.ts或者main.js文件中引入/App.vue报错(/App.vue不是模块)

情况二、vue3.0+ts

报错显示
vue3+vite在main.ts或者main.js文件中引入/App.vue报错(/App.vue不是模块)
报错原因:typescript只能理解.ts文件,无法理解.vue文件。

方案一:根目录新建env.d.ts

在根目录新建env.d.ts文件,写入以下内容:

declare module '*.vue' {
  import type { DefineComponent } from 'vue'
  // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types
  const component: DefineComponent<{}, {}, any>
  export default component
}

vue3+vite在main.ts或者main.js文件中引入/App.vue报错(/App.vue不是模块)
也可以解决问题,缺点是需要一直打开

方案二:根目录新建tsconfig.json

在根目录新建tsconfig.json文件,写入以下内容

{
  "compilerOptions": {
    "target": "esnext",
    "module": "esnext",
    "strict": false,
    "jsx": "preserve",
    "moduleResolution": "node"
  }
}

此时报错已解决 👇👇👇
vue3+vite在main.ts或者main.js文件中引入/App.vue报错(/App.vue不是模块)

觉得这篇文章有用的小伙伴们

可以点赞➕收藏➕关注哦~