VuePressVuePress
首页
  • 基础
  • UI
  • JavaScript
  • CSS
  • postcss
  • Vue3
  • Vue的设计与实现
  • 前端常用插件
  • PHP
  • Laravel
  • Linux
  • 线性代数
Category
AI
jiyun
Timeline
首页
  • 基础
  • UI
  • JavaScript
  • CSS
  • postcss
  • Vue3
  • Vue的设计与实现
  • 前端常用插件
  • PHP
  • Laravel
  • Linux
  • 线性代数
Category
AI
jiyun
Timeline
  • 基础知识

    • ref&reactive
    • watchEffect
    • 响应式: 工具函数
    • 组合式函数
    • 防止ref不会自动解包
    • 注入全局属性
  • 虚拟节点

    • 虚拟节点介绍
    • component 属性
    • component.proxy
    • appContext
  • 组件

    • 函数式组件
  • 过渡和动画

    • 函数式组件
  • vite

    • import.meta.glob
    • import.meta.url
      • URL
  • demo

    • 打印面单-雏形
    • 打印面单-多模板

import.meta.url 简介

import.meta.url 是一个 ESM 的原生功能,会暴露当前模块的 URL。 将它与原生的 URL 构造器 组合使用,在一个 JavaScript 模块中,通过相对路径我们就能得到一个被完整解析的静态资源 URL:

const imgUrl = new URL('./img.png', import.meta.url).href
document.getElementById('hero-img').src = imgUrl

这在现代浏览器中能够原生使用 - 实际上,Vite 并不需要在开发阶段处理这些代码!

这个模式同样还可以通过字符串模板支持动态 URL:

function getImageUrl(name) {
  return new URL(`./dir/${name}.png`, import.meta.url).href
}

在生产构建时,Vite 才会进行必要的转换保证 URL 在打包和资源哈希后仍指向正确的地址。然而,这个 URL 字符串必须是静态的,这样才好分析。否则代码将被原样保留、因而在 build.target 不支持 import.meta.url 时会导致运行时错误。

// Vite 不会转换这个
const imgUrl = new URL(imagePath, import.meta.url).href

import.meta.url 在浏览器和 Node.js 中有不同的语义。

特定的 __filename 和 __dirname 在 ES 模块中不被允许,我们需要使用可替换的 import.meta.url 替换。它包含一个绝对路径的 URL 文件。举例来说:'file:///Users/rauschma/my-module.mjs'

URL

URL() 构造函数返回一个新创建的 URL 对象,该对象表示由参数定义的 URL。

如果给定的基本 URL 或生成的 URL 不是有效的 URL,则会抛出 JavaScript TypeError 异常。

语法:

new URL(url)
new URL(url, base)
  • url
    一个表示绝对或相对 URL 的 DOMString 或任何具有字符串化方法的对象,例如 <a> 或 <area> 元素。如果 url 是相对 URL,则会将 base 用作基准 URL。如果 url 是绝对 URL,则无论参数 base 是否存在,都将被忽略。
  • base 可选
    一个表示基准 URL 的字符串,当 url 为相对 URL 时,它才会生效。如果未指定,它默认为 undefined
Last Updated:
Contributors: BaronYan
Prev
import.meta.glob