feat(experimental): shouldTransform for ref-transform
This commit is contained in:
parent
0c2ea1c134
commit
e565831c98
@ -142,24 +142,9 @@ export function walkFunctionParams(
|
|||||||
onIdent: (id: Identifier) => void
|
onIdent: (id: Identifier) => void
|
||||||
) {
|
) {
|
||||||
for (const p of node.params) {
|
for (const p of node.params) {
|
||||||
;(walk as any)(p, {
|
for (const id of extractIdentifiers(p)) {
|
||||||
enter(child: Node, parent: Node) {
|
onIdent(id)
|
||||||
if (
|
}
|
||||||
child.type === 'Identifier' &&
|
|
||||||
// do not record as scope variable if is a destructured key
|
|
||||||
!isStaticPropertyKey(child, parent) &&
|
|
||||||
// do not record if this is a default value
|
|
||||||
// assignment of a destructured variable
|
|
||||||
!(
|
|
||||||
parent &&
|
|
||||||
parent.type === 'AssignmentPattern' &&
|
|
||||||
parent.right === child
|
|
||||||
)
|
|
||||||
) {
|
|
||||||
onIdent(child)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,7 +51,10 @@ import { compileTemplate, SFCTemplateCompileOptions } from './compileTemplate'
|
|||||||
import { warnExperimental, warnOnce } from './warn'
|
import { warnExperimental, warnOnce } from './warn'
|
||||||
import { rewriteDefault } from './rewriteDefault'
|
import { rewriteDefault } from './rewriteDefault'
|
||||||
import { createCache } from './cache'
|
import { createCache } from './cache'
|
||||||
import { transformAST as transformWithRefSugar } from '@vue/ref-transform'
|
import {
|
||||||
|
shouldTransform,
|
||||||
|
transformAST as transformWithRefSugar
|
||||||
|
} from '@vue/ref-transform'
|
||||||
|
|
||||||
// Special compiler macros
|
// Special compiler macros
|
||||||
const DEFINE_PROPS = 'defineProps'
|
const DEFINE_PROPS = 'defineProps'
|
||||||
@ -855,7 +858,7 @@ export function compileScript(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 3. Apply ref sugar transform
|
// 3. Apply ref sugar transform
|
||||||
if (enableRefSugar) {
|
if (enableRefSugar && shouldTransform(source)) {
|
||||||
warnExperimental(
|
warnExperimental(
|
||||||
`ref sugar`,
|
`ref sugar`,
|
||||||
`https://github.com/vuejs/rfcs/discussions/369`
|
`https://github.com/vuejs/rfcs/discussions/369`
|
||||||
|
@ -37,6 +37,17 @@ A few commonly used APIs have shorthands (which also removes the need to import
|
|||||||
|
|
||||||
This package is the lower-level transform that can be used standalone. Higher-level tooling (e.g. `@vitejs/plugin-vue` and `vue-loader`) will provide integration via options.
|
This package is the lower-level transform that can be used standalone. Higher-level tooling (e.g. `@vitejs/plugin-vue` and `vue-loader`) will provide integration via options.
|
||||||
|
|
||||||
|
### `shouldTransform`
|
||||||
|
|
||||||
|
Can be used to do a cheap check to determine whether full transform should be performed.
|
||||||
|
|
||||||
|
```js
|
||||||
|
import { shouldTransform } from '@vue/ref-transform'
|
||||||
|
|
||||||
|
shouldTransform(`let a = ref(0)`) // false
|
||||||
|
shouldTransform(`let a = $ref(0)`) // true
|
||||||
|
```
|
||||||
|
|
||||||
### `transform`
|
### `transform`
|
||||||
|
|
||||||
```js
|
```js
|
||||||
@ -66,6 +77,8 @@ interface RefTransformOptions {
|
|||||||
|
|
||||||
### `transformAST`
|
### `transformAST`
|
||||||
|
|
||||||
|
Transform with an existing Babel AST + MagicString instance. This is used internally by `@vue/compiler-sfc` to avoid double parse/transform cost.
|
||||||
|
|
||||||
```js
|
```js
|
||||||
import { transformAST } from '@vue/ref-transform'
|
import { transformAST } from '@vue/ref-transform'
|
||||||
import { parse } from '@babel/parser'
|
import { parse } from '@babel/parser'
|
||||||
|
@ -24,6 +24,11 @@ import { babelParserDefaultPlugins } from '@vue/shared'
|
|||||||
const TO_VAR_SYMBOL = '$'
|
const TO_VAR_SYMBOL = '$'
|
||||||
const TO_REF_SYMBOL = '$$'
|
const TO_REF_SYMBOL = '$$'
|
||||||
const shorthands = ['ref', 'computed', 'shallowRef']
|
const shorthands = ['ref', 'computed', 'shallowRef']
|
||||||
|
const transformCheckRE = /[^\w]\$(?:\$|ref|computed|shallowRef)?\(/
|
||||||
|
|
||||||
|
export function shouldTransform(src: string): boolean {
|
||||||
|
return transformCheckRE.test(src)
|
||||||
|
}
|
||||||
|
|
||||||
export interface ReactiveDeclarator {
|
export interface ReactiveDeclarator {
|
||||||
node: VariableDeclarator
|
node: VariableDeclarator
|
||||||
|
Loading…
x
Reference in New Issue
Block a user