feat(experimental): shouldTransform for ref-transform

This commit is contained in:
Evan You 2021-08-23 10:45:58 -04:00
parent 0c2ea1c134
commit e565831c98
4 changed files with 26 additions and 20 deletions

View File

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

View File

@ -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`

View File

@ -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'

View File

@ -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