2.0.1 • Published 2 years ago

rollup-plugin-san v2.0.1

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

rollup-plugin-san

rollup-plugin-san 是一个支持 .san 单文件组件的 rollup 插件。

rollup-plugin-san

类似 webpack 的 san-loader 插件,它同样支持以下特性:

  • scoped css

  • css modules

  • less 等 css 预处理器(需要自行安装配套包)

  • pug 等 html 预处理器(需要自行安装配套包)

  • typescript 等 js 方言(需要自行安装配套包)

  • aNode / aPack => 文档

等等。

快速上手

安装:

npm i rollup-plugin-san --save-dev

然后编写 rollup.config.js

import PluginSan from 'rollup-plugin-san';

export default [
  {
    input: 'src/App.san',
    output: {
      file: 'dist/app.js',
      format: 'esm',
      sourcemap: 'none',
    },
    plugins: [PluginSan()],
    external: ['san'],
  },
];

examples 里包含了绝大多数的开发场景的示例,比如热更新、压缩混淆、图片引入、ts 支持、copy 文件等等。

设置

名称描述类型
include包含的文件或目录string / RegExp / (string / RegExp)[];
exclude排除的文件或目录string / RegExp / (string / RegExp)[];
templateCompileOptionscompileTemplate 选项Object
styleCompileOptionscompileStyle 选项Object

templateCompileOptions 和 styleCompileOptions 详见 san-sfc-compiler

说明

插件

  • rollup 插件执行顺序和配置文件数组顺序是一致的,所以配置时候注意先后顺序

  • css 的处理需要安装 rollup-plugin-postcss

  • 一般来说 @rollup/plugin-node-resolve 是必备的,不然会出现找不到模块的问题

  • 默认输出 ESM 模块,可自行配置 babel 来转换语法

打包

  • 分包,参考 examples/complex 的 rollup.config.js,此时 san 可以通过 cdn 引入

  • 全量打包需要 rollup 的 commonjs 插件,并将 external 和 output.global 去掉,这样 san 才能全部打包到一起

其他

关于 sfc 写法可参考 webpack san-loader,这里不再重复

反馈

所有 san 相关的项目都支持以下反馈方式:

协议

MIT. Copyright (c) Baidu Inc. All rights reserved.

参考

感谢以下项目:

2.0.1

2 years ago

2.0.0

2 years ago

1.0.4

3 years ago

1.0.3

3 years ago

1.0.2

3 years ago

1.0.1

3 years ago

1.0.0

3 years ago