From 4da92f027dfc3082d3c0c422eb45f5069805a3c7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adri=C3=A0=20Fontcuberta?= Date: Tue, 25 Jun 2019 21:04:01 +0200 Subject: [PATCH 1/4] feat: Warn on colon shorthand usage on directive fix #10191 --- src/compiler/parser/index.js | 7 +++++++ test/unit/modules/compiler/parser.spec.js | 5 +++++ 2 files changed, 12 insertions(+) diff --git a/src/compiler/parser/index.js b/src/compiler/parser/index.js index cdeb257eda4..a5beec78c86 100644 --- a/src/compiler/parser/index.js +++ b/src/compiler/parser/index.js @@ -30,6 +30,7 @@ export const forIteratorRE = /,([^,\}\]]*)(?:,([^,\}\]]*))?$/ const stripParensRE = /^\(|\)$/g const dynamicArgRE = /^\[.*\]$/ +const colonDirRE = /^:v-/ const argRE = /:(.*)$/ export const bindRE = /^:|^\.|^v-bind:/ const propBindRE = /^\./ @@ -761,6 +762,12 @@ function processAttrs (el) { for (i = 0, l = list.length; i < l; i++) { name = rawName = list[i].name value = list[i].value + // :v-if or similar + if (process.env.NODE_ENV !== 'production' && colonDirRE.test(name)) { + warn( + `A v-bind shorthand directive was used on another Vue directive. Did you want to write '${name.substr(1)}="${value}"'?` + ) + } if (dirRE.test(name)) { // mark element as dynamic el.hasBindings = true diff --git a/test/unit/modules/compiler/parser.spec.js b/test/unit/modules/compiler/parser.spec.js index d6521bbf625..ae3804ead52 100644 --- a/test/unit/modules/compiler/parser.spec.js +++ b/test/unit/modules/compiler/parser.spec.js @@ -530,6 +530,11 @@ describe('parser', () => { expect(ast.props[0].value).toBe('msg') }) + it('v-bind expression on directive', () => { + parse('
', baseOptions) + expect(`A v-bind shorthand directive was used on another Vue directive. Did you want to write 'v-if="foo"'?`).toHaveBeenWarned() + }) + it('empty v-bind expression', () => { parse('
', baseOptions) expect('The value for a v-bind expression cannot be empty. Found in "v-bind:empty-msg"').toHaveBeenWarned() From 2279242b7a31e52f13890988420116979cccc371 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adri=C3=A0=20Fontcuberta?= Date: Wed, 26 Jun 2019 18:10:18 +0200 Subject: [PATCH 2/4] Update test/unit/modules/compiler/parser.spec.js Co-Authored-By: Eduardo San Martin Morote --- test/unit/modules/compiler/parser.spec.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/unit/modules/compiler/parser.spec.js b/test/unit/modules/compiler/parser.spec.js index ae3804ead52..c5306fb7c33 100644 --- a/test/unit/modules/compiler/parser.spec.js +++ b/test/unit/modules/compiler/parser.spec.js @@ -530,7 +530,7 @@ describe('parser', () => { expect(ast.props[0].value).toBe('msg') }) - it('v-bind expression on directive', () => { + it('warns when using v-bind shorthand on a directive', () => { parse('
', baseOptions) expect(`A v-bind shorthand directive was used on another Vue directive. Did you want to write 'v-if="foo"'?`).toHaveBeenWarned() }) From ee1c09315ac9b8647a9f31fa962deb5b4442e0d3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adri=C3=A0=20Fontcuberta?= Date: Wed, 26 Jun 2019 18:41:59 +0200 Subject: [PATCH 3/4] feat: Make error message more explicit --- src/compiler/parser/index.js | 2 +- test/unit/modules/compiler/parser.spec.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/compiler/parser/index.js b/src/compiler/parser/index.js index a5beec78c86..faec1f1cb7a 100644 --- a/src/compiler/parser/index.js +++ b/src/compiler/parser/index.js @@ -765,7 +765,7 @@ function processAttrs (el) { // :v-if or similar if (process.env.NODE_ENV !== 'production' && colonDirRE.test(name)) { warn( - `A v-bind shorthand directive was used on another Vue directive. Did you want to write '${name.substr(1)}="${value}"'?` + `A v-bind shorthand was used on another Vue directive. Did you mean '${name.substr(1)}="${value}"' instead of '${name}'?` ) } if (dirRE.test(name)) { diff --git a/test/unit/modules/compiler/parser.spec.js b/test/unit/modules/compiler/parser.spec.js index c5306fb7c33..e338e134ea2 100644 --- a/test/unit/modules/compiler/parser.spec.js +++ b/test/unit/modules/compiler/parser.spec.js @@ -532,7 +532,7 @@ describe('parser', () => { it('warns when using v-bind shorthand on a directive', () => { parse('
', baseOptions) - expect(`A v-bind shorthand directive was used on another Vue directive. Did you want to write 'v-if="foo"'?`).toHaveBeenWarned() + expect(`A v-bind shorthand was used on another Vue directive. Did you mean 'v-if="foo"' instead of ':v-if'?`).toHaveBeenWarned() }) it('empty v-bind expression', () => { From f695a6d70532a9fcde1b380b6c4e2678d3a95884 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Adri=C3=A0=20Fontcuberta?= Date: Wed, 26 Jun 2019 19:21:50 +0200 Subject: [PATCH 4/4] feat: Improve message context --- src/compiler/parser/index.js | 2 +- test/unit/modules/compiler/parser.spec.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/compiler/parser/index.js b/src/compiler/parser/index.js index faec1f1cb7a..3389354dfc5 100644 --- a/src/compiler/parser/index.js +++ b/src/compiler/parser/index.js @@ -765,7 +765,7 @@ function processAttrs (el) { // :v-if or similar if (process.env.NODE_ENV !== 'production' && colonDirRE.test(name)) { warn( - `A v-bind shorthand was used on another Vue directive. Did you mean '${name.substr(1)}="${value}"' instead of '${name}'?` + `A v-bind shorthand was used on another Vue directive. Did you mean '${name.substr(1)}="${value}"' instead of '${name}="${value}"'?` ) } if (dirRE.test(name)) { diff --git a/test/unit/modules/compiler/parser.spec.js b/test/unit/modules/compiler/parser.spec.js index e338e134ea2..56971a14955 100644 --- a/test/unit/modules/compiler/parser.spec.js +++ b/test/unit/modules/compiler/parser.spec.js @@ -532,7 +532,7 @@ describe('parser', () => { it('warns when using v-bind shorthand on a directive', () => { parse('
', baseOptions) - expect(`A v-bind shorthand was used on another Vue directive. Did you mean 'v-if="foo"' instead of ':v-if'?`).toHaveBeenWarned() + expect(`A v-bind shorthand was used on another Vue directive. Did you mean 'v-if="foo"' instead of ':v-if="foo"'?`).toHaveBeenWarned() }) it('empty v-bind expression', () => {