refactor(compiler): remove modelValue from generated code for native v-model
This commit is contained in:
parent
3b2d236714
commit
9eef37fa32
@ -8,9 +8,8 @@ return function render(_ctx, _cache) {
|
|||||||
const { vModelDynamic: _vModelDynamic, mergeProps: _mergeProps, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
const { vModelDynamic: _vModelDynamic, mergeProps: _mergeProps, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", _mergeProps(obj, {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", _mergeProps(obj, {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}), null, 16 /* FULL_PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}), null, 16 /* FULL_PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_vModelDynamic, model]
|
[_vModelDynamic, model]
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
@ -27,9 +26,8 @@ return function render(_ctx, _cache) {
|
|||||||
const _directive_bind = _resolveDirective(\\"bind\\")
|
const _directive_bind = _resolveDirective(\\"bind\\")
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_directive_bind, val, key],
|
[_directive_bind, val, key],
|
||||||
[_vModelDynamic, model]
|
[_vModelDynamic, model]
|
||||||
])
|
])
|
||||||
@ -45,9 +43,8 @@ return function render(_ctx, _cache) {
|
|||||||
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[
|
[
|
||||||
_vModelText,
|
_vModelText,
|
||||||
model,
|
model,
|
||||||
@ -67,9 +64,8 @@ return function render(_ctx, _cache) {
|
|||||||
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[
|
[
|
||||||
_vModelText,
|
_vModelText,
|
||||||
model,
|
model,
|
||||||
@ -89,9 +85,8 @@ return function render(_ctx, _cache) {
|
|||||||
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[
|
[
|
||||||
_vModelText,
|
_vModelText,
|
||||||
model,
|
model,
|
||||||
@ -111,9 +106,8 @@ return function render(_ctx, _cache) {
|
|||||||
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_vModelText, model]
|
[_vModelText, model]
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
@ -129,9 +123,8 @@ return function render(_ctx, _cache) {
|
|||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
type: \\"checkbox\\",
|
type: \\"checkbox\\",
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_vModelCheckbox, model]
|
[_vModelCheckbox, model]
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
@ -148,9 +141,8 @@ return function render(_ctx, _cache) {
|
|||||||
const _directive_bind = _resolveDirective(\\"bind\\")
|
const _directive_bind = _resolveDirective(\\"bind\\")
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_directive_bind, foo, \\"type\\"],
|
[_directive_bind, foo, \\"type\\"],
|
||||||
[_vModelDynamic, model]
|
[_vModelDynamic, model]
|
||||||
])
|
])
|
||||||
@ -167,9 +159,8 @@ return function render(_ctx, _cache) {
|
|||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
type: \\"radio\\",
|
type: \\"radio\\",
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_vModelRadio, model]
|
[_vModelRadio, model]
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
@ -185,9 +176,8 @@ return function render(_ctx, _cache) {
|
|||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"input\\", {
|
||||||
type: \\"text\\",
|
type: \\"text\\",
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_vModelText, model]
|
[_vModelText, model]
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
@ -202,9 +192,8 @@ return function render(_ctx, _cache) {
|
|||||||
const { vModelSelect: _vModelSelect, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
const { vModelSelect: _vModelSelect, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"select\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"select\\", {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_vModelSelect, model]
|
[_vModelSelect, model]
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
@ -219,9 +208,8 @@ return function render(_ctx, _cache) {
|
|||||||
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
const { vModelText: _vModelText, createVNode: _createVNode, withDirectives: _withDirectives, openBlock: _openBlock, createBlock: _createBlock } = _Vue
|
||||||
|
|
||||||
return _withDirectives((_openBlock(), _createBlock(\\"textarea\\", {
|
return _withDirectives((_openBlock(), _createBlock(\\"textarea\\", {
|
||||||
modelValue: model,
|
|
||||||
\\"onUpdate:modelValue\\": $event => (model = $event)
|
\\"onUpdate:modelValue\\": $event => (model = $event)
|
||||||
}, null, 8 /* PROPS */, [\\"modelValue\\", \\"onUpdate:modelValue\\"])), [
|
}, null, 8 /* PROPS */, [\\"onUpdate:modelValue\\"])), [
|
||||||
[_vModelText, model]
|
[_vModelText, model]
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
|
@ -104,5 +104,17 @@ export const transformModel: DirectiveTransform = (dir, node, context) => {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// native vmodel doesn't need the `modelValue` props since they are also
|
||||||
|
// passed to the runtime as `binding.value`. removing it reduces code size.
|
||||||
|
baseResult.props = baseResult.props.filter(p => {
|
||||||
|
if (
|
||||||
|
p.key.type === NodeTypes.SIMPLE_EXPRESSION &&
|
||||||
|
p.key.content === 'modelValue'
|
||||||
|
) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
|
||||||
return baseResult
|
return baseResult
|
||||||
}
|
}
|
||||||
|
@ -25,19 +25,18 @@ export const patchProp: RendererOptions<Node, Element>['patchProp'] = (
|
|||||||
case 'style':
|
case 'style':
|
||||||
patchStyle(el, prevValue, nextValue)
|
patchStyle(el, prevValue, nextValue)
|
||||||
break
|
break
|
||||||
case 'modelValue':
|
|
||||||
case 'onUpdate:modelValue':
|
|
||||||
// Do nothing. This is handled by v-model directives.
|
|
||||||
break
|
|
||||||
default:
|
default:
|
||||||
if (isOn(key)) {
|
if (isOn(key)) {
|
||||||
patchEvent(
|
// ignore v-model listeners
|
||||||
el,
|
if (key.indexOf('onUpdate:') < 0) {
|
||||||
key.slice(2).toLowerCase(),
|
patchEvent(
|
||||||
prevValue,
|
el,
|
||||||
nextValue,
|
key.slice(2).toLowerCase(),
|
||||||
parentComponent
|
prevValue,
|
||||||
)
|
nextValue,
|
||||||
|
parentComponent
|
||||||
|
)
|
||||||
|
}
|
||||||
} else if (!isSVG && key in el) {
|
} else if (!isSVG && key in el) {
|
||||||
patchDOMProp(
|
patchDOMProp(
|
||||||
el,
|
el,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user