【问题标题】:How to add stylus support to svelte & rollup如何将手写笔支持添加到 svelte & rollup
【发布时间】:2020-11-28 16:46:27
【问题描述】:

我不知道我做错了什么。我只是想在我的苗条文件中使用手写笔。本质上,我想尝试适应https://github.com/sveltejs/svelte-preprocess/tree/main/examples/sapper-rollup。如前所述,使用打字稿和手写笔。

当我添加如下所示的手写笔代码时,我总是收到错误 cannot read length of undefined。它适用于纯 CSS。例如 SCSS 也不起作用。

// rollup.config.js
import babel from '@rollup/plugin-babel'
import commonjs from '@rollup/plugin-commonjs'
import config from 'sapper/config/rollup.js'
import path from 'path'
import pkg from './package.json'
import replace from '@rollup/plugin-replace'
import resolve from '@rollup/plugin-node-resolve'
import svelte from 'rollup-plugin-svelte'
import sveltePreprocess from 'svelte-preprocess'
import typescript from '@rollup/plugin-typescript'
import url from '@rollup/plugin-url'
import { terser } from 'rollup-plugin-terser'

const mode = process.env.NODE_ENV
const dev = mode === 'development'
const legacy = !!process.env.SAPPER_LEGACY_BUILD

const onwarn = (warning, onwarn) =>
   (warning.code === 'MISSING_EXPORT' && /'preload'/.test(warning.message)) ||
   (warning.code === 'CIRCULAR_DEPENDENCY' && /[/\\]@sapper[/\\]/.test(warning.message)) ||
   (warning.code === 'THIS_IS_UNDEFINED') ||
   onwarn(warning)

export default {
   client: {
      input: config.client.input().replace(/\.js$/, '.ts'),
      output: config.client.output(),
      plugins: [
         replace({
            'process.browser': true,
            'process.env.NODE_ENV': JSON.stringify(mode)
         }),
         svelte({
            dev,
            hydratable: true,
            preprocess: sveltePreprocess({
               stylus: {
                  includePaths: ['src'],
               },
               postcss: {
                  plugins: [require('postcss-import')],
               },
            }),
            emitCss: true
         }),
         url({
            sourceDir: path.resolve(__dirname, 'src/node_modules/images'),
            publicPath: '/client/'
         }),
         resolve({
            browser: true,
            dedupe: ['svelte']
         }),
         commonjs(),
         typescript({ sourceMap: dev }),

         legacy && babel({
            extensions: ['.js', '.mjs', '.html', '.svelte'],
            babelHelpers: 'runtime',
            exclude: ['node_modules/@babel/**'],
            presets: [
               ['@babel/preset-env', {
                  targets: '> 0.25%, not dead'
               }]
            ],
            plugins: [
               '@babel/plugin-syntax-dynamic-import',
               ['@babel/plugin-transform-runtime', {
                  useESModules: true
               }]
            ]
         }),

         !dev && terser({
            module: true
         })
      ],

      preserveEntrySignatures: false,
      onwarn,
   },

   server: {
      input: { server: config.server.input().server.replace(/\.js$/, ".ts") },
      output: config.server.output(),
      plugins: [
         replace({
            'process.browser': false,
            'process.env.NODE_ENV': JSON.stringify(mode)
         }),
         svelte({
            generate: 'ssr',
            hydratable: true,
            preprocess: sveltePreprocess(),
            dev
         }),
         url({
            sourceDir: path.resolve(__dirname, 'src/node_modules/images'),
            publicPath: '/client/',
            emitFiles: false // already emitted by client build
         }),
         resolve({
            dedupe: ['svelte']
         }),
         commonjs(),
         typescript({ sourceMap: dev })
      ],
      external: Object.keys(pkg.dependencies).concat(require('module').builtinModules),

      preserveEntrySignatures: 'strict',
      onwarn,
   },

   serviceworker: {
      input: config.serviceworker.input().replace(/\.js$/, '.ts'),
      output: config.serviceworker.output(),
      plugins: [
         resolve(),
         replace({
            'process.browser': true,
            'process.env.NODE_ENV': JSON.stringify(mode)
         }),
         commonjs(),
         typescript({ sourceMap: dev }),
         !dev && terser()
      ],

      preserveEntrySignatures: false,
      onwarn,
   }
}

这里是一个示例代码sn-p

// component
<style type="text/stylus">
  main
    position relative
    max-width 56em
    background-color white
    padding 2em
    margin 0 auto
    box-sizing border-box
</style>

我认为错误出在我的 rollup.config.js 中,但我不知道/不明白我做错了什么。

【问题讨论】:

  • 错误说明出了什么问题。某处 .length 在未定义的变量上被调用。该错误还应该说明它正在发生的文件和行。

标签: svelte stylus rollup


【解决方案1】:

这是svelte-preprocesssvelte@3.30 之间的兼容性问题。

你不是唯一一个面临这个问题的人(或者你是打开这个问题的人?):https://github.com/sveltejs/svelte-preprocess/issues/284

这很可能是由于 Svelte 3.30 在预处理器中增加了对源映射的支持:https://github.com/sveltejs/svelte/blob/master/CHANGELOG.md#3300

降级到 svelte@3.29 现在应该可以解决您的问题:

yarn add -D svelte@3.29

而且,嗯... 本来以为您需要在 Sapper 应用程序的 clientserver 中使用完全相同的 preprocess 配置。您可能想检查一下。

【讨论】:

  • 注意:这似乎只是 Sapper 中的问题,出于某种原因(svelte-preprocess + svelte@3.30 在“原始”Svelte 项目中工作)。
猜你喜欢
  • 1970-01-01
  • 2011-04-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-02-10
  • 2017-08-29
  • 1970-01-01
相关资源
最近更新 更多