首页 > 解决方案 > rollup - 如何在 JS 目标文件夹之外编写 CSS

问题描述

Svelte 使用 Rollup 进行捆绑。这是文件夹结构。

svelte/
├── node_modules/
├── public/
│   ├── bundle.js
│   └── bundle.css
├── src/
│   ├── App.svelte
│   └── main.js
└── rollup.config.js

我想同时保存根文件夹bundle.jsbundle.css根文件夹之外。

这是汇总配置。

input: "src/main.js",
    output: {
        format: "cjs",
        name: "app",
        file: "../../src/svelte/bundle.js",
    },
    plugins: [
        svelte({
            css: (css) => {
                css.write("/bundle.css");
            },
        }),
    ],

我可以保存bundle.js罚款,但传递给css.write()for的路径bundle.css对于bundle.js目标目录的。

如果我尝试这样做css.write("../bundle.css"),我会收到此错误...

Error: The "fileName" or "name" properties of emitted files must be strings that are neither absolute 
nor relative paths and do not contain invalid characters, received "/bundle-svelte-activities.css".

标签: javascriptbundlersvelterollup

解决方案


这里有一些片段来实现它:

...
import css from 'rollup-plugin-css-asset';

export default {
    input: 'src/main.js',
    output: {
        sourcemap: true,
        format: 'iife',
        name: 'app',
        assetFileNames: 'bundle.css',
        dir: 'public/build',
        entryFileNames: 'bundle.js'
    },
    plugins: [
       svelte({
            ...
            emitCss: true,
       }),
       ...
       css({   
           name: 'bundle',
       }),
       ...
     ],
     ...  

推荐阅读