gpt4 book ai didi

Vue3: Cannot find module './assets/logo.png' or its corresponding type declarations(Vue3:找不到模块‘./Assets/logo.png’或其对应的类型声明)

转载 作者:bug小助手 更新时间:2023-10-24 21:54:29 29 4
gpt4 key购买 nike



I made the simplest project using

我做了一个最简单的项目


vue create testtype3

command:

命令:


enter image description here


App.vue:

附录:


<template>
<img alt="Vue logo" src="./assets/logo.png">

<img :src="MyIcon" />

</template>

<script lang="ts">
import { defineComponent } from 'vue';
import MyIcon from './assets/logo.png';


export default defineComponent({
name: 'App',
components: {


},

setup(props, { emit }) {
return {
MyIcon
}
}
});
</script>

main.ts:

main.ts:


import { createApp } from 'vue'
import App from './App.vue'

createApp(App).mount('#app')

index.d.ts:

index.d.ts:


import { createApp } from 'vue'
import App from './App.vue'

createApp(App).mount('#app')

babel.config.js:

Babel.config.js:


module.exports = {
presets: [
'@vue/cli-plugin-babel/preset'
]
}

package.json:

Package.json:


{
"name": "testtype3",
"version": "0.1.0",
"private": true,
"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"lint": "vue-cli-service lint"
},
"dependencies": {
"core-js": "^3.8.3",
"vue": "^3.2.13"
},
"devDependencies": {
"@typescript-eslint/eslint-plugin": "^5.4.0",
"@typescript-eslint/parser": "^5.4.0",
"@vue/cli-plugin-babel": "~5.0.0",
"@vue/cli-plugin-eslint": "~5.0.0",
"@vue/cli-plugin-typescript": "~5.0.0",
"@vue/cli-service": "~5.0.0",
"@vue/eslint-config-typescript": "^9.1.0",
"eslint": "^7.32.0",
"eslint-plugin-vue": "^8.0.3",
"file-loader": "^6.2.0",
"typescript": "~4.5.5"
}
}

tsconfig.json:

Tsconfig.json:


{
"compilerOptions": {
"target": "esnext",
"module": "esnext",
"strict": true,
"jsx": "preserve",
"moduleResolution": "node",
"skipLibCheck": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"forceConsistentCasingInFileNames": true,
"useDefineForClassFields": true,
"sourceMap": true,
"baseUrl": ".",
"types": [
"webpack-env"
],
"paths": {
"@/*": [
"src/*"
]
},
"lib": [
"esnext",
"dom",
"dom.iterable",
"scripthost"
]
},
"include": [
"src/**/*.ts",
"src/**/*.tsx",
"src/**/*.vue",
"tests/**/*.ts",
"tests/**/*.tsx"
],
"exclude": [
"node_modules"
]
}

vue.config.js:

Vue.config.js:


const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
transpileDependencies: true
})

The App displays a logo in two ways: passing a path String to an img and by passing an imported MyLogo to an img. However, I get an error for the second approach:

该应用程序以两种方式显示徽标:将路径字符串传递给IMG和将导入的MyLogo传递给IMG。但是,对于第二种方法,我得到了一个错误:


TS2307: Cannot find module './assets/logo.png' or its corresponding type declarations.
<script lang="ts">
import { defineComponent } from 'vue';
import MyIcon from './assets/logo.png';
^^^^^^^^^^^^^^^^^^^

Removing the MyIcon import and the img element that uses MyIcon results in npm run serve running without problems.

删除MyIcon导入和使用MyIcon的img元素会导致NPM Run Serve正常运行。


I made a types folder in the root directory and created a index.d.ts there, however the error still persists.

我在根目录中创建了一个Types文件夹,并在那里创建了一个index.d.ts,但是错误仍然存在。


更多回答

I'd strongly suggest you migrate the build system to Vite. The Vue CLI is now deprecated

我强烈建议您将构建系统迁移到VITE。Vue CLI现在已弃用

See here for the Vue CLI instructions for what you're trying to do though cli.vuejs.org/guide/…

查看此处的Vue CLI说明,了解您尝试通过cl.vuejs.org/GUIDE/…执行的操作

@Phil Thank you for the advice. I migrated the project to Vite and now it works. I'll leave the question open, however, as someone might encounter the same issue without having an ability to migrate

@菲尔,谢谢你的建议。我将该项目迁移到了VITE,现在它可以工作了。然而,我将保留这个问题,因为没有迁移能力的人可能会遇到同样的问题

The original question is answered by following the documentation for Vue CLI. Basically you use require() or just a regular src attribute

按照Vue CLI的文档回答了最初的问题。基本上,您可以使用Required()或仅使用常规src属性

优秀答案推荐

you should edit index.d.ts to this:

您应该将index.d.ts编辑为:


declare module '*.png' {
const value: string;
export = value;
}

also you should add a line to tsconfig.json so it should look like this:

另外,你应该在tslog.json中添加一行,这样它应该看起来像这样:


{
"compilerOptions": {
"target": "esnext",
"module": "esnext",
"strict": true,
"jsx": "preserve",
"moduleResolution": "node",
"skipLibCheck": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"forceConsistentCasingInFileNames": true,
"useDefineForClassFields": true,
"sourceMap": true,
"baseUrl": ".",
"types": [
"webpack-env"
],
"paths": {
"@/*": [
"src/*"
]
},
"lib": [
"esnext",
"dom",
"dom.iterable",
"scripthost"
]
},
"include": [
// add this line
"types/index.d.ts",
"src/**/*.ts",
"src/**/*.tsx",
"src/**/*.vue",
"tests/**/*.ts",
"tests/**/*.tsx"
],
"exclude": [
"node_modules"
]
}

更多回答

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com