Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/g-plane/swc-plugin-vue-jsx

SWC plugin for transforming Vue JSX.
https://github.com/g-plane/swc-plugin-vue-jsx

jsx swc-plugin vue

Last synced: 4 days ago
JSON representation

SWC plugin for transforming Vue JSX.

Awesome Lists containing this project

README

        

# SWC Plugin for Vue JSX

SWC plugin for transforming Vue JSX, mostly ported from [official Babel plugin](https://github.com/vuejs/babel-plugin-jsx).
It only supports Vue.js v3 or newer.

## Installation

```
npm i -D swc-plugin-vue-jsx
```

## Configuration

You can configure your `.swcrc` file.

### Minimum Config

```json
{
"jsc": {
"parser": {
"syntax": "ecmascript",
"jsx": true
},
"experimental": {
"plugins": [["swc-plugin-vue-jsx", {}]]
}
}
}
```

### Options

These options of official Babel plugin are supported:

- `transformOn`
- `optimize`
- `mergeProps`
- `enableObjectSlots`
- `pragma`
- `resolveType` (Types imported from other modules aren't supported.)

For details, please refer to official documentation.

The `isCustomElement` can't be supported directly, because SWC config only allows JSON,
so we introduce the `customElementPatterns` option instead.

It accepts an array of strings which represent regex.

For example:

```json
[
"swc-plugin-vue-jsx",
{
"customElementPatterns": ["^i-"]
}
]
```

All HTML tags which match the pattern `^i-` will be treated as custom elements.

### Advanced Config Example

```json
{
"jsc": {
"parser": {
"syntax": "ecmascript",
"jsx": true
},
"experimental": {
"plugins": [
[
"swc-plugin-vue-jsx",
{
"transformOn": true,
"optimize": true
}
]
]
}
}
}
```

## License

MIT License

Copyright (c) 2022-present Pig Fang