From 3ce49496a34939933f09bc94e3feb4dfd04d2649 Mon Sep 17 00:00:00 2001 From: Jokcy Date: Tue, 12 Jan 2021 14:41:08 +0800 Subject: [PATCH 1/3] fix: reload all components anyway when hmr in jsx --- packages/plugin-vue-jsx/index.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/packages/plugin-vue-jsx/index.js b/packages/plugin-vue-jsx/index.js index 6e9546be103646..bf929f8dc774fa 100644 --- a/packages/plugin-vue-jsx/index.js +++ b/packages/plugin-vue-jsx/index.js @@ -165,9 +165,7 @@ function vueJsxPlugin(options = {}) { `\n${local}.__hmrId = "${id}"` + `\n${local}.__hmrHash = "${hash}"` + `\n__VUE_HMR_RUNTIME__.createRecord("${id}", ${local})` - callbackCode += - `\n if (__${exported}.__hmrHash !== ${local}.__hmrHash) ` + - `__VUE_HMR_RUNTIME__.reload("${id}", __${exported})` + callbackCode += `__VUE_HMR_RUNTIME__.reload("${id}", __${exported})` } code += `\nimport.meta.hot.accept(({${hotComponents From 3bb8d432785c0ed9479e200c42561915c6e44716 Mon Sep 17 00:00:00 2001 From: Jokcy Date: Tue, 12 Jan 2021 14:46:07 +0800 Subject: [PATCH 2/3] fix: remove code hash since we not compare anymore --- packages/plugin-vue-jsx/index.js | 25 ++++++++----------------- 1 file changed, 8 insertions(+), 17 deletions(-) diff --git a/packages/plugin-vue-jsx/index.js b/packages/plugin-vue-jsx/index.js index bf929f8dc774fa..5c99e95de77a9e 100644 --- a/packages/plugin-vue-jsx/index.js +++ b/packages/plugin-vue-jsx/index.js @@ -62,7 +62,7 @@ function vueJsxPlugin(options = {}) { // check for hmr injection /** - * @type {{ name: string, hash: string }[]} + * @type {{ name: string }[]} */ const declaredComponents = [] /** @@ -70,7 +70,6 @@ function vueJsxPlugin(options = {}) { * local: string, * exported: string, * id: string, - * hash: string * }[]} */ const hotComponents = [] @@ -91,11 +90,10 @@ function vueJsxPlugin(options = {}) { ) { hotComponents.push( ...parseComponentDecls(node.declaration, code).map( - ({ name, hash: _hash }) => ({ + ({ name }) => ({ local: name, exported: name, - id: hash(id + name), - hash: _hash + id: hash(id + name) }) ) ) @@ -112,8 +110,7 @@ function vueJsxPlugin(options = {}) { hotComponents.push({ local: spec.local.name, exported: spec.exported.name, - id: hash(id + spec.exported.name), - hash: matched.hash + id: hash(id + spec.exported.name) }) } } @@ -131,8 +128,7 @@ function vueJsxPlugin(options = {}) { hotComponents.push({ local: node.declaration.name, exported: 'default', - id: hash(id + 'default'), - hash: matched.hash + id: hash(id + 'default') }) } } else if (isDefineComponentCall(node.declaration)) { @@ -140,10 +136,7 @@ function vueJsxPlugin(options = {}) { hotComponents.push({ local: '__default__', exported: 'default', - id: hash(id + 'default'), - hash: hash( - code.slice(node.declaration.start, node.declaration.end) - ) + id: hash(id + 'default') }) } } @@ -160,10 +153,9 @@ function vueJsxPlugin(options = {}) { } let callbackCode = `` - for (const { local, exported, id, hash } of hotComponents) { + for (const { local, exported, id } of hotComponents) { code += `\n${local}.__hmrId = "${id}"` + - `\n${local}.__hmrHash = "${hash}"` + `\n__VUE_HMR_RUNTIME__.createRecord("${id}", ${local})` callbackCode += `__VUE_HMR_RUNTIME__.reload("${id}", __${exported})` } @@ -193,8 +185,7 @@ function parseComponentDecls(node, source) { for (const decl of node.declarations) { if (decl.id.type === 'Identifier' && isDefineComponentCall(decl.init)) { names.push({ - name: decl.id.name, - hash: hash(source.slice(decl.init.start, decl.init.end)) + name: decl.id.name }) } } From b6eb1371e927b1bd5d350d1a66db1721bf8c5ccc Mon Sep 17 00:00:00 2001 From: Jokcy Date: Tue, 12 Jan 2021 17:37:19 +0800 Subject: [PATCH 3/3] fix: fix tests for jsx-plugin --- .../playground/vue-jsx/__tests__/vue-jsx.spec.ts | 12 +++++++----- packages/plugin-vue-jsx/index.js | 2 +- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/packages/playground/vue-jsx/__tests__/vue-jsx.spec.ts b/packages/playground/vue-jsx/__tests__/vue-jsx.spec.ts index 3a54cfdbf011e4..104d3bd52642b9 100644 --- a/packages/playground/vue-jsx/__tests__/vue-jsx.spec.ts +++ b/packages/playground/vue-jsx/__tests__/vue-jsx.spec.ts @@ -1,4 +1,4 @@ -import { editFile, isBuild, untilUpdated } from '../../testUtils' +import { editFile, isBuild, untilUpdated } from 'testUtils' test('should render', async () => { expect(await page.textContent('.named')).toMatch('0') @@ -25,9 +25,10 @@ if (!isBuild) { ) await untilUpdated(() => page.textContent('.named'), 'named updated 0') - // should not affect other components on the page - expect(await page.textContent('.named-specifier')).toMatch('2') - expect(await page.textContent('.default')).toMatch('3') + // affect all components in same file + expect(await page.textContent('.named-specifier')).toMatch('1') + expect(await page.textContent('.default')).toMatch('2') + // should not affect other components from different file expect(await page.textContent('.default-tsx')).toMatch('4') }) @@ -40,8 +41,9 @@ if (!isBuild) { 'named specifier updated 1' ) + // affect all components in same file + expect(await page.textContent('.default')).toMatch('2') // should not affect other components on the page - expect(await page.textContent('.default')).toMatch('3') expect(await page.textContent('.default-tsx')).toMatch('4') }) diff --git a/packages/plugin-vue-jsx/index.js b/packages/plugin-vue-jsx/index.js index 5c99e95de77a9e..86d27be65008b2 100644 --- a/packages/plugin-vue-jsx/index.js +++ b/packages/plugin-vue-jsx/index.js @@ -157,7 +157,7 @@ function vueJsxPlugin(options = {}) { code += `\n${local}.__hmrId = "${id}"` + `\n__VUE_HMR_RUNTIME__.createRecord("${id}", ${local})` - callbackCode += `__VUE_HMR_RUNTIME__.reload("${id}", __${exported})` + callbackCode += `\n__VUE_HMR_RUNTIME__.reload("${id}", __${exported})` } code += `\nimport.meta.hot.accept(({${hotComponents