MCPcopy Index your code
hub / github.com/vuejs/babel-plugin-jsx

github.com/vuejs/babel-plugin-jsx @v3.0.0 sqlite

repository ↗ · DeepWiki ↗ · release v3.0.0 ↗
76 symbols 176 edges 24 files 2 documented · 3%
README

Babel Plugin JSX for Vue 3

npm package issues-helper

To add Vue JSX support.

English | 简体中文

Installation

Install the plugin with:

npm install @vue/babel-plugin-jsx -D

Then add the plugin to your babel config:

{
  "plugins": ["@vue/babel-plugin-jsx"]
}

Usage

options

transformOn

Type: boolean

Default: false

transform on: { click: xx } to onClick: xxx

optimize

Type: boolean

Default: false

When enabled, this plugin generates optimized runtime code using PatchFlags and SlotFlags to improve rendering performance. However, due to JSX's dynamic nature, the optimizations are not as comprehensive as those in Vue's official template compiler.

Since the optimized code may skip certain re-renders to improve performance, we strongly recommend thorough testing of your application after enabling this option to ensure everything works as expected.

isCustomElement

Type: (tag: string) => boolean

Default: undefined

configuring custom elements

mergeProps

Type: boolean

Default: true

merge static and dynamic class / style attributes / onXXX handlers

enableObjectSlots

Type: boolean

Default: true

Whether to enable object slots (mentioned below the document) syntax". It might be useful in JSX, but it will add a lot of _isSlot condition expressions which increase your bundle size. And v-slots is still available even if enableObjectSlots is turned off.

pragma

Type: string

Default: createVNode

Replace the function used when compiling JSX expressions.

resolveType

Type: boolean

Default: false

(Experimental) Infer component metadata from types (e.g. props, emits, name). This is an experimental feature and may not work in all cases.

Syntax

Content

functional component

const App = () => 

Vue 3.0


with render

const App = {
  render() {
    return 

Vue 3.0


  },
}
import { defineComponent, withModifiers } from 'vue'

const App = defineComponent({
  setup() {
    const count = ref(0)

    const inc = () => {
      count.value++
    }

    return () => 

{count.value}


  },
})

Fragment

function App() {
  return (
    <>
      <span>I'm</span>
      <span>Fragment</span>
    </>
  )
}

Attributes / Props

const App = () => <input type="email" />

with a dynamic binding:

const placeholderText = 'email'
const App = () => <input type="email" placeholder={placeholderText} />

Directives

v-show

const App = {
  data() {
    return { visible: true }
  },
  render() {
    return <input v-show={this.visible} />
  },
}

v-model

Note: You should pass the second param as string for using arg.

<input v-model={val} />
<input v-model:argument={val} />
;<input v-model={[val, ['modifier']]} />
// Or
;<input v-model_modifier={val} />
;<A v-model={[val, 'argument', ['modifier']]} />
// Or
;<input v-model:argument_modifier={val} />

Will compile to:

h(A, {
  argument: val,
  argumentModifiers: {
    modifier: true,
  },
  'onUpdate:argument': ($event) => (val = $event),
})

v-models (Not recommended since v1.1.0)

Note: You should pass a Two-dimensional Arrays to v-models.

<A v-models={[[foo], [bar, 'bar']]} />
<A
  v-models={[
    [foo, 'foo'],
    [bar, 'bar'],
  ]}
/>
<A
  v-models={[
    [foo, ['modifier']],
    [bar, 'bar', ['modifier']],
  ]}
/>

Will compile to:

h(A, {
  modelValue: foo,
  modelModifiers: {
    modifier: true,
  },
  'onUpdate:modelValue': ($event) => (foo = $event),
  bar,
  barModifiers: {
    modifier: true,
  },
  'onUpdate:bar': ($event) => (bar = $event),
})

custom directive

Recommended when using string arguments

const App = {
  directives: { custom: customDirective },
  setup() {
    return () => <a v-custom:arg={val} />
  },
}
const App = {
  directives: { custom: customDirective },
  setup() {
    return () => <a v-custom={[val, 'arg', ['a', 'b']]} />
  },
}

Slot

Note: In jsx, v-slot should be replaced with v-slots

function A(props, { slots }) {
  return (
    <>
      <h1>{slots.default ? slots.default() : 'foo'}</h1>
      <h2>{slots.bar?.()}</h2>
    </>
  )
}

const App = {
  setup() {
    const slots = {
      bar: () => <span>B</span>,
    }
    return () => (
      <A v-slots={slots}>


A


      </A>
    )
  },
}

// or

const App2 = {
  setup() {
    const slots = {
      default: () => 

A

,
      bar: () => <span>B</span>,
    }
    return () => <A v-slots={slots} />
  },
}

// or you can use object slots when `enableObjectSlots` is not false.
const App3 = {
  setup() {
    return () => (
      <>
        <A>
          {{
            default: () => 

A

,
            bar: () => <span>B</span>,
          }}
        </A>
        <B>{() => 'foo'}</B>
      </>
    )
  },
}

In TypeScript

tsconfig.json:

{
  "compilerOptions": {
    "jsx": "preserve"
  }
}

Who is using

Ant Design Vue Vant Element Plus Vue Json Pretty

Compatibility

This repo is only compatible with:

  • Babel 8+
  • Vue 3+

Extension points exported contracts — how you extend this code

Test (Interface)
(no doc)
packages/babel-plugin-jsx/test/snapshot.test.ts
PersistedState (Interface)
(no doc)
packages/jsx-explorer/src/index.ts
VueJSXPluginOptions (Interface)
(no doc)
packages/babel-plugin-jsx/src/interface.ts

Core symbols most depended-on inside this repo

createIdentifier
called by 15
packages/babel-plugin-jsx/src/utils.ts
transformJSXElement
called by 3
packages/babel-plugin-jsx/src/transform-vue-jsx.ts
buildIIFE
called by 3
packages/babel-plugin-jsx/src/utils.ts
dedupeProperties
called by 3
packages/babel-plugin-jsx/src/utils.ts
addProperty
called by 3
packages/babel-plugin-resolve-type/src/index.ts
resolveTypeReference
called by 3
packages/babel-plugin-resolve-type/src/index.ts
getTypeAnnotation
called by 3
packages/babel-plugin-resolve-type/src/index.ts
isDirective
called by 2
packages/babel-plugin-jsx/src/utils.ts

Shape

Function 73
Interface 3

Languages

TypeScript100%

Modules by API surface

packages/babel-plugin-jsx/src/utils.ts18 symbols
packages/babel-plugin-resolve-type/src/index.ts17 symbols
packages/babel-plugin-jsx/test/index.test.tsx8 symbols
packages/babel-plugin-jsx/src/transform-vue-jsx.ts5 symbols
packages/jsx-explorer/src/index.ts4 symbols
packages/babel-plugin-jsx/test/v-models.test.tsx4 symbols
packages/babel-plugin-jsx/test/v-model.test.tsx4 symbols
packages/babel-plugin-jsx/src/parseDirectives.ts4 symbols
packages/jsx-explorer/src/options.tsx2 symbols
packages/babel-plugin-jsx/test/snapshot.test.ts2 symbols
packages/babel-plugin-jsx/src/sugar-fragment.ts2 symbols
packages/babel-plugin-jsx/src/index.ts2 symbols

Dependencies from manifests, versioned

@arethetypeswrong/corecatalog: · 1×
@babel/code-framecatalog: · 1×
@babel/corecatalog: · 1×
@babel/helper-module-importscatalog: · 1×
@babel/helper-plugin-utilscatalog: · 1×
@babel/parsercatalog: · 1×
@babel/plugin-syntax-jsxcatalog: · 1×
@babel/plugin-syntax-typescriptcatalog: · 1×
@babel/preset-envcatalog: · 1×
@babel/standalonecatalog: · 1×
@babel/templatecatalog: · 1×
@babel/typescatalog: · 1×

For agents

$ claude mcp add babel-plugin-jsx \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact