gpt4 book ai didi

typescript - 插件 typescript : @rollup/plugin-typescript TS2307: Cannot find module './App.svelte' or its corresponding type declarations

转载 作者:行者123 更新时间:2023-12-04 03:24:15 24 4
gpt4 key购买 nike

我的 slim 项目有以下问题
主文件

import App from './App.svelte';

const app = new App({
target: document.body,
});

export default app;
第一行返回警告

Plugin typescript: @rollup/plugin-typescript TS2307: Cannot find module './App.svelte' or its corresponding type declarations.


但我的配置看起来没问题我确实安装并添加了 "@tsconfig/svelte": "^2.0.1",到我的 tsconfig
汇总配置文件
import svelte from 'rollup-plugin-svelte';
import commonjs from '@rollup/plugin-commonjs';
import resolve from '@rollup/plugin-node-resolve';
import livereload from 'rollup-plugin-livereload';
import { terser } from 'rollup-plugin-terser';
import typescript from '@rollup/plugin-typescript';
import css from 'rollup-plugin-css-only';
import preprocess from 'svelte-preprocess';
import alias from '@rollup/plugin-alias';

const production = !process.env.ROLLUP_WATCH;

function serve() {
let server;

function toExit() {
if (server) server.kill(0);
}

return {
writeBundle() {
if (server) return;
server = require('child_process').spawn('npm', ['run', 'start', '--', '--dev'], {
stdio: ['ignore', 'inherit', 'inherit'],
shell: true,
});

process.on('SIGTERM', toExit);
process.on('exit', toExit);
},
};
}

export default {
input: 'src/main.ts',
output: {
sourcemap: true,
format: 'iife',
name: 'app',
file: 'public/build/bundle.js',
},
plugins: [
svelte({
preprocess: preprocess({
sourceMap: !production,
postcss: true,
}),
compilerOptions: {
// enable run-time checks when not in production
dev: !production,
},
}),
// we'll extract any component CSS out into
// a separate file - better for performance
css({ output: 'bundle.css' }),
alias({
resolve: ['.svelte', '.ts'], //optional, by default this will just look for .js files or folders
entries: [
{ find: '@assets', replacement: 'src/assets/' },
{ find: '@components', replacement: 'src/components/' },
{ find: '@libs', replacement: 'src/libs/' },
{ find: '@routes', replacement: 'src/routes/' },
{ find: '@models', replacement: 'src/models/' },
{ find: '@constants', replacement: 'src/constants/' },
{ find: '@services', replacement: 'src/services/' },
],
}),
// If you have external dependencies installed from
// npm, you'll most likely need these plugins. In
// some cases you'll need additional configuration -
// consult the documentation for details:
// https://github.com/rollup/plugins/tree/master/packages/commonjs
resolve({
browser: true,
dedupe: ['svelte'],
}),
commonjs(),
typescript({
sourceMap: !production,
inlineSources: !production,
resolveJsonModule: true,
}),

// In dev mode, call `npm run start` once
// the bundle has been generated
!production && serve(),

// Watch the `public` directory and refresh the
// browser on changes when not in production
!production && livereload('public'),

// If we're building for production (npm run build
// instead of npm run dev), minify
production && terser(),
],
watch: {
clearScreen: false,
},
};

配置文件
{
"extends": "@tsconfig/svelte/tsconfig.json",
"include": ["src/**/*", "**/*.config.js"],
"exclude": ["node_modules/*", "__sapper__/*", "public/*"],
"compilerOptions": {
"baseUrl": "./",
"strict": true,
"forceConsistentCasingInFileNames": true,
"paths": {
"@assets/*": ["src/assets/*"],
"@components/*": ["src/components/*"],
"@libs/*": ["src/libs/*"],
"@routes/*": ["src/routes/*"],
"@models/*": ["src/models/*"],
"@constants/*": ["src/constants/*"],
"@services/*": ["src/services/*"]
}
}
}
我可以导入 .svelte.svelte文件,但不是 .svelte .ts 中的文件文件

最佳答案

@tsconfig/svelte版本 1.x 确实包括 "types": ["svelte"] .这确保了 TypeScript 找到了环境 Svelte 类型定义,它告诉 TypeScript Svelte 导入是“正常的”。但与此同时,它关闭了所有其他环境类型定义,例如来自 Jest 的那些会导致混淆。因此,在版本 2 中,types字段被删除。您现在需要自己添加环境定义或对它的引用。
在您的 src 内文件夹创建 global.d.ts文件与

/// <reference types="svelte" />
这与 "types": ["svelte"] 的功能基本相同在 tsconfig.json之前并告诉 TS 在哪里可以找到环境类型定义。

关于typescript - 插件 typescript : @rollup/plugin-typescript TS2307: Cannot find module './App.svelte' or its corresponding type declarations,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67907079/

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