From be3a4f5beb39a83bb62aef19f9e18177047618fa Mon Sep 17 00:00:00 2001 From: Evan You Date: Tue, 30 Mar 2021 20:37:23 -0400 Subject: [PATCH] fix: do not inject ?import query to external urls --- packages/vite/src/client/client.ts | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/packages/vite/src/client/client.ts b/packages/vite/src/client/client.ts index 6ced6863c20897..366896293b0490 100644 --- a/packages/vite/src/client/client.ts +++ b/packages/vite/src/client/client.ts @@ -177,7 +177,7 @@ async function waitForSuccessfulPing(ms = 1000) { await fetch(`${base}__vite_ping`) break } catch (e) { - await new Promise(resolve => setTimeout(resolve, ms)) + await new Promise((resolve) => setTimeout(resolve, ms)) } } } @@ -433,16 +433,19 @@ export const createHotContext = (ownerPath: string) => { return hot } +/** + * urls here are dynamic import() urls that couldn't be statically analyzed + */ export function injectQuery(url: string, queryToInject: string) { - // can't use pathname from URL since it may be relative like ../ - const pathname = url.replace(/#.*$/, '').replace(/\?.*$/, '') - const { search, hash, protocol } = new URL(url, 'http://vitejs.dev') - - // data URLs shouldn't be appended queries, #2658 - if (protocol === 'blob:' || protocol === 'data:') { + // skip urls that won't be handled by vite + if (!url.startsWith('.') && !url.startsWith('/')) { return url } + // can't use pathname from URL since it may be relative like ../ + const pathname = url.replace(/#.*$/, '').replace(/\?.*$/, '') + const { search, hash } = new URL(url, 'http://vitejs.dev') + return `${pathname}?${queryToInject}${search ? `&` + search.slice(1) : ''}${ hash || '' }`