我的 svelte 项目有以下问题
main.ts
import App from './App.svelte';
const app = new App({
target: document.body,
});
export default app;
第一行返回警告
<块引用>插件打字稿:@rollup/plugin-typescript TS2307:找不到模块“./App.svelte”或其对应的类型声明。
但我的配置看起来没问题我确实安装并将 "@tsconfig/svelte": "^2.0.1",
添加到我的 tsconfig
rollup.config.js
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,
},
};
tsconfig.json
{
"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
个文件
答案 0 :(得分:2)
@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 在哪里可以找到环境类型定义。