插件打字稿:@rollup/plugin-typescript TS2307:找不到模块“./App.svelte”或其相应的类型声明

时间:2021-06-09 15:17:18

标签: typescript svelte rollup rollupjs svelte-3

我的 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 个文件

1 个答案:

答案 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 在哪里可以找到环境类型定义。