diff --git a/packages/vite/src/node/plugins/assetImportMetaUrl.ts b/packages/vite/src/node/plugins/assetImportMetaUrl.ts index 1b2473137c5431..03686fc638cb9a 100644 --- a/packages/vite/src/node/plugins/assetImportMetaUrl.ts +++ b/packages/vite/src/node/plugins/assetImportMetaUrl.ts @@ -3,7 +3,12 @@ import MagicString from 'magic-string' import { stripLiteral } from 'strip-literal' import type { Plugin } from '../plugin' import type { ResolvedConfig } from '../config' -import { injectQuery, isParentDirectory, transformStableResult } from '../utils' +import { + injectQuery, + isDataUrl, + isParentDirectory, + transformStableResult, +} from '../utils' import { CLIENT_ENTRY } from '../constants' import { slash } from '../../shared/utils' import { createBackCompatIdResolver } from '../idResolver' @@ -102,6 +107,9 @@ export function assetImportMetaUrlPlugin(config: ResolvedConfig): Plugin { } const url = rawUrl.slice(1, -1) + if (isDataUrl(url)) { + continue + } let file: string | undefined if (url[0] === '.') { file = slash(path.resolve(path.dirname(id), url)) diff --git a/playground/assets/__tests__/assets.spec.ts b/playground/assets/__tests__/assets.spec.ts index 5f2f6af6082763..842209d1f147b9 100644 --- a/playground/assets/__tests__/assets.spec.ts +++ b/playground/assets/__tests__/assets.spec.ts @@ -440,6 +440,18 @@ test('new URL("/...", import.meta.url)', async () => { ) }) +test('new URL("data:...", import.meta.url)', async () => { + const img = await page.$('.import-meta-url-data-uri-img') + expect( + (await img.getAttribute('src')).startsWith('data:image/png;base64'), + ).toBe(true) + expect( + (await page.textContent('.import-meta-url-data-uri')).startsWith( + 'data:image/png;base64', + ), + ).toBe(true) +}) + test('new URL(..., import.meta.url) without extension', async () => { expect(await page.textContent('.import-meta-url-without-extension')).toMatch( isBuild ? 'data:text/javascript' : 'nested/test.js', diff --git a/playground/assets/index.html b/playground/assets/index.html index cf79dab2830275..17858c6692d82d 100644 --- a/playground/assets/index.html +++ b/playground/assets/index.html @@ -250,6 +250,10 @@

new URL('/...', import.meta.url)

+

new URL('data:...', import.meta.url)

+ + +

new URL('...', import.meta.url (without extension))

@@ -498,6 +502,13 @@

assets in template

text('.import-meta-url-base-path', metaUrlBasePath) document.querySelector('.import-meta-url-base-path-img').src = metaUrlBasePath + const metaUrlDataUri = new URL( + '', + import.meta.url, + ) + text('.import-meta-url-data-uri', metaUrlDataUri) + document.querySelector('.import-meta-url-data-uri-img').src = metaUrlDataUri + const metaUrlWithoutExtension = new URL('./nested/test', import.meta.url) text('.import-meta-url-without-extension', metaUrlWithoutExtension) ;(async () => {