Vite静态资源处理——动态引入图片

这篇具有很好参考价值的文章主要介绍了Vite静态资源处理——动态引入图片。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

单一资源处理

将资源引入为 URL

服务时引入一个静态资源会返回解析后的公共路径:

// 引用
import CaseBG from '@/assets/images/20230313144252.png'

导入既可以使用绝对公共路径(基于开发期间的项目根路径),也可以使用相对路径。

// 使用
<img alt='' :src=CaseBG />

vite 生产构建后文件名会哈希,如图:

vite 动态加载图片,Vite,javascript,vue.js,前端,vite

多个资源处理(动态)

new URL(url, import.meta.url)

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

// 引用
const CaseBG = new URL('@/assets/images/20230313144252.png', import.meta.url).href
// 使用
<img alt='' :src=CaseBG />

如果想要动态引入图片资源,可以通过字符串模板封装一个方法:

/**
 * 动态引入图片资源
 * @param {String} name 图片名称/路径
 * @returns 图片url
 */
export const getImageUrl = (name) => {
  return new URL(`../assets/images/${name}`, import.meta.url).href
}

需要注意的是:

  • 如果 name 想要传路径的话,比如图片资源在 images 下不同的文件夹中,即 home/20230313144252.png,那这个路径就需要传文件后缀。
<img
  alt=""
  :src="getImageUrl('home/20230314145534.png')"
  style="width: 214px; height: 46px;"
/>

写成这样的格式才能正确显示。

  • 如果 name 只是传文件名的话,就可以把后缀直接写在封装的方法中:
export const getImage = (name) => (
  new URL(`../assets/images/${name}.png`, import.meta.url).href
)
<img
  alt=""
  :src="getImage('20230313094342')"
  style="width: 214px; height: 46px;"
/>

这样的话,就可以省略文件后缀了。

需要注意的是:

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

两个知识点:

new URL()

创建并返回一个 URL 对象,该 URL 对象引用使用绝对 URL 字符串,相对 URL 字符串和基本 URL 字符串指定的 URL

import.meta

import.meta 是一个给 JavaScript 模块暴露特定上下文的元数据属性的对象。它包含了这个模块的信息,比如说这个模块的 URL

Public 目录

另外说一下一些特殊情况,可以解决路径问题。
如果有下列这些资源:

  • 不会被源码引用(例如 robots.txt
  • 必须保持原有文件名(没有经过 hash
  • 等等一些压根不想引入该资源,只是想得到其 URL

那么就可以将该资源放在指定的 public 目录中,它应位于项目根目录。该目录中的资源在开发时能直接通过 / 根路径访问到,并且打包时会被完整复制到目标目录的根目录下。

目录默认是 <root>/public,但可以通过 publicDir 选项 来配置。

请注意:文章来源地址https://www.toymoban.com/news/detail-691912.html

  • 引入 public 中的资源永远应该使用根绝对路径 —— 举个例子,public/icon.png 应该在源码中被引用为 /icon.png
  • public 中的资源不应该被 JavaScript 文件引用。

到了这里,关于Vite静态资源处理——动态引入图片的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vite搭建的项目动态引入本地图片

    由于vite里面没有require(), 所以需要封装个工具。

    2024年02月11日
    浏览(59)
  • 如何在Vite项目中处理静态资源

    在前端工程化建设中,静态资源是必须处理的一个问题,前端的静态资源通常包括图片、JSON、Worker 文件、Web Assembly 文件等等。由于静态资源本身并不是一个标准意义上的模块,因此在处理静态资源和代码时是需要区别对待的。 对于资源加载问题,Vite需要处理的就是如何将

    2023年04月26日
    浏览(47)
  • 解决项目迁移vite引入图片资源报require is not defined的问题

    Vite是一种轻量快速的前端构建工具,能够显著提升前端开发体验,而且官方已经发布v4版本,相对比较稳定。在把VueCli搭建的项目迁移到Vite的过程中遇到了个问题,下面分享一下问题及解决办法。 在 script 标签里面引入的图片资源没生效,然后一看控制台,报错显示 require

    2024年02月03日
    浏览(48)
  • Vue3的vite中图片的动态加载

    vite官网的静态资源引入参考地址 new URL() + import.meta.url 注意:这里只能通过 …/…/ 这种方式去获取路径,无法通过@/assets

    2024年02月16日
    浏览(37)
  • vite.config.ts 自动导入静态资源 或 cdn资源

    效果

    2024年02月10日
    浏览(42)
  • VUE3+vite项目中动态引入组件和异步组件

    1. 把项目中所有vue文件注册成异步组件。 2. 获取组件 在setup函数获取组件 3. 参考如下 Glob 导入 Vite 支持使用特殊的 import.meta.glob 函数从文件系统导入多个模块: 以上将会被转译为下面的样子: 你可以遍历 modules 对象的 key 值来访问相应的模块: 匹配到的文件默认是懒加载的

    2024年02月10日
    浏览(105)
  • 解决vite构建库模式和 es 格式中css样式加载问题(也可单独在组件下引入)

    注:如果同一个项目使用多个组件,引入的CSS样式名相同会导致CSS样式来回覆盖导致错误 3. 安装 4. 用法

    2024年02月03日
    浏览(45)
  • 《Vite 基础知识》使用 Glob 动态加载 .vue 文件

    开发基于 Vite + Vue3 的组件库,多个 .vue 文件需要动态加载! 注意 import.meta.globEager 已经弃用,请使用 import.meta.glob 来代替! 代码第 1 行,注意使用两个 **,匹配当前目录及其嵌套的全部子目录下的文件; 代码第 4 行,异步使用 Promise 加载,所以要在 then 中获取真正的组件对

    2024年01月18日
    浏览(44)
  • vite图片处理

    主要问题点:解决打包速度,尽量用框架自带的方法,不要想着以前的。就像人总会变。 写一个插件 export default function requirePlugin() {     return {       // 插件名称       name: \\\"vite-plugin-vue-requireToUrlPlugin\\\",       // 默认值post:在 Vite 核心插件之后调用该插件,pre:在 Vite 核心

    2024年02月12日
    浏览(23)
  • flutter项目引入本地静态图片资源并展示

    想要在flutter中引入静态资源,需要配置pubspec.yaml,将本地的静态资源添加到assets下面: 然后在flutter引入这些静态资源:  就可以在app中看到这个图片了:  也可以使用网络图片:

    2024年02月05日
    浏览(61)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包