test('should error if no expression', () => {
const onError = jest.fn()
- parseWithVBind(`<div v-bind:arg />`, { onError })
+ const node = parseWithVBind(`<div v-bind:arg />`, { onError })
+ const props = (node.codegenNode as VNodeCall).props as ObjectExpression
expect(onError.mock.calls[0][0]).toMatchObject({
code: ErrorCodes.X_V_BIND_NO_EXPRESSION,
loc: {
}
}
})
+ expect(props.properties[0]).toMatchObject({
+ key: {
+ content: `arg`,
+ isStatic: true
+ },
+ value: {
+ content: ``,
+ isStatic: true
+ }
+ })
})
test('.camel modifier', () => {
export const transformBind: DirectiveTransform = (dir, node, context) => {
const { exp, modifiers, loc } = dir
const arg = dir.arg!
- if (!exp || (exp.type === NodeTypes.SIMPLE_EXPRESSION && !exp.content)) {
- context.onError(createCompilerError(ErrorCodes.X_V_BIND_NO_EXPRESSION, loc))
- }
// .prop is no longer necessary due to new patch behavior
// .sync is replaced by v-model:arg
if (modifiers.includes('camel')) {
arg.children.push(`)`)
}
}
+
+ if (
+ !exp ||
+ (exp.type === NodeTypes.SIMPLE_EXPRESSION && !exp.content.trim())
+ ) {
+ context.onError(createCompilerError(ErrorCodes.X_V_BIND_NO_EXPRESSION, loc))
+ return {
+ props: [createObjectProperty(arg!, createSimpleExpression('', true, loc))]
+ }
+ }
+
return {
- props: [
- createObjectProperty(arg!, exp || createSimpleExpression('', true, loc))
- ]
+ props: [createObjectProperty(arg!, exp)]
}
}