Vue3+vite 处理静态资源,解决服务器不显示动态循环img问题

注意:

vue2+webpack中,通常使用require来动态渲染静态资源。但在vue3+vite中,不支持require语法,因此使用require会报undefined,所以官方推荐使用import来动态渲染静态资源。

实现方式动态渲染静态资源

vue2+webpack

使用require引入静态资源 require('xxxx' + 变量)

javascript 复制代码
  		<div
            :class="['tag-item', currentSystem == item.code ? 'activeTag' : '']"
            v-for="(item, index) in schoolTagsList"
            :key="index"
            @click="getCurrentTypeSchoolList(item)"
          >
            <img class="tag-icon" :src="require(`../../assets/img/${item.code}.png`)" alt="" /> 
            {{ item.value}}
          </div>

vue3+vite

使用 new URL(url, import.meta.url)

vite官网静态资源处理 new URL(url, import.meta.url)

import.meta.url : ESM 的原生功能,会暴露当前模块的 URL

与原生的 URL 构造器 组合使用,在一个 JavaScript 模块中,通过相对路径我们就能得到一个被完整解析的静态资源 URL

注意哈

注意这个URL 字符串必须是静态的,这样才能分析

否则代码将被原样保留,因而在 build.target 不支持 import.meta.url 时会导致运行时错误

javascript 复制代码
 function test(name) {
  return new URL(`../${name}.png`, import.meta.url).href
}
相关推荐
愚者Pro3 小时前
Flutter Widget组件学习(专为 Uniapp 转 Flutter 定制)
vue.js·学习·flutter·uni-app
前端毕业班5 小时前
uniapp web 灵活控制 style scoped
前端·javascript·vue.js
卤蛋fg66 小时前
vxe-table 数据分组 + 单元格图表:柱状图与饼图渲染实战
vue.js
用户841794814567 小时前
vxe-table 数据分组:三种展示方式详解
vue.js
LJA648449 小时前
用 MCP + 一句话生成了完整的 CRUD 页面
vue.js
梵得儿SHI10 小时前
Vue 项目实战与性能优化:工程化与协作全指南(规范 + 配置 + 协作 + 文档)
前端·vue.js·代码规范·eslint·团队协作·前端工程化·前端架构
xjf771110 小时前
AI 可读性与识别能力对比-TypeDom vs Vue
前端·vue.js·人工智能
蜡台11 小时前
Vue2 + TS,分路径参数、查询参数、装饰器组件 / Vue.extend 两种写法,同时补充类型约束、监听路由、动态路由取值。
前端·javascript·vue.js·router
用户85748243548011 小时前
useList 通用列表管理hook
vue.js·微信小程序
Ciito13 小时前
Win11 系统运行 node 项目 network: unavailable 问题解决
前端·vue.js