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 () => {