@vue/babel-sugar-composition-api-render-instance
Babel syntactic sugar for replaceing `this` with `getCurrentInstance()` in Vue JSX with @vue/composition-api
Last updated 2 years ago by soda .
MIT · Repository · Bugs · Original npm · Tarball · package.json
$ gnpm install @vue/babel-sugar-composition-api-render-instance 
SYNC missed versions from official npm registry.

@vue/babel-sugar-composition-api-render-instance

Ported from luwanquan/babel-preset-vca-jsx by @luwanquan

Babel syntactic sugar for replacing this with getCurrentInstance() in Vue JSX with @vue/composition-api

Babel Compatibility Notes

  • This repo is only compatible with Babel 7.x

Usage

Install the dependencies:

# for yarn:
yarn add @vue/babel-sugar-composition-api-render-instance
# for npm:
npm install @vue/babel-sugar-composition-api-render-instance --save

In your .babelrc:

{
  "plugins": ["@vue/babel-sugar-composition-api-render-instance"]
}

However it is recommended to use the configurable preset instead.

Details

This plugin automatically replaces this in setup() with getCurrentInstance(). This is required for JSX to work in @vue/composition-api as this is not available in setup()

Input:

defineComponent({ 
  setup() {
    return () => <MyComponent vModel={a.b} />
  }
})

Output (without @vue/babel-sugar-composition-api-render-instance):

defineComponent({
  setup() {
    return () => <MyComponent model={{
      value: a.b,
      callback: $$v => {
        this.$set(a, "b", $$v);
      }
    }} />
  }
})

Output (with @vue/babel-sugar-composition-api-render-instance):

import { getCurrentInstance } from "@vue/composition-api";

defineComponent({
  setup() {
    const __currentInstance = getCurrentInstance();

    return () => <MyComponent model={{
      value: a.b,
      callback: $$v => {
        __currentInstance.$set(a, "b", $$v);
      }
    }} />
  }
})

Current Tags

  • 1.4.0                                ...           latest (2 years ago)

5 Versions

  • 1.4.0                                ...           2 years ago
  • 1.3.0                                ...           2 years ago
  • 1.2.4                                ...           4 years ago
  • 1.2.1                                ...           4 years ago
  • 1.2.0                                ...           4 years ago
Downloads
Today 0
This Week 0
This Month 0
Last Day 0
Last Week 0
Last Month 0
Dependencies (1)
Dev Dependencies (10)
Dependents (1)

Copyright 2013 - present © cnpmjs.org | Home |