Files
Lemon f5e6e29f00 Merge branch 'dev-zza' into dev
# Conflicts:
#	jsowell-ui/.env.development
#	jsowell-ui/.env.staging
#	jsowell-ui/bin/build-sit.bat
#	jsowell-ui/bin/build.bat
#	jsowell-ui/src/api/adapayMember/adapayMember.js
#	jsowell-ui/src/api/pile/merchant.js
#	jsowell-ui/src/router/index.js
#	jsowell-ui/src/views/financial/financeDetail.vue
#	jsowell-ui/src/views/financial/merchant.vue
#	jsowell-ui/src/views/homeIndex/homeIndex.vue
#	jsowell-ui/src/views/login.vue
#	jsowell-ui/src/views/pile/basic/detail.vue
#	jsowell-ui/src/views/pile/station/components/SiteInfo.vue
#	jsowell-ui/src/views/pile/station/detail.vue
#	jsowell-ui/src/views/pile/station/orderReport.vue
2025-06-03 14:26:37 +08:00

1.7 KiB

@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);
      }
    }} />
  }
})