为什么 js 对象中引用本地图片需要写 require 或 import

1、模块化系统的要求:

现代前端工程(如 Vue、React)使用 webpack / vite 等构建工具,这些工具要求所有静态资源必须显式声明依赖;

require / import 是告诉 webpack / vite 这个文件是我的项目依赖,请处理它,如果直接写成普通路径(如:img: '@/assets/apply/p.jpg')会被当成字符串,webpack / vite 不会处理这个文件;

2、构建工具的工作流程:

1.找到图片文件;

2.压缩/优化图片;

3.将图片复制到输出目录(如 dist 文件夹);

4.返回最终的文件路径;

3、路径转换问题:

开发时可能写的相对路径,但构建后的文件结构会变化,require 会动态解析路径,确保无论构建后的文件如何分布,最终路径都是正确的;

require 和import区别:

可以把 require 和import 想象成两种不同的的"快递服务",都能帮你把本地图片送到网页显示,但服务方式不同:

|----------|---------------------------|------------------------------|
| 特点 | require (CommonJS) | import (ES odule) |
| 调用时机 | 任何地方随时调用 | 必须在文件顶部先声明 |
| 支持环境 | Node.js原生支持 | 现代浏览器原生支持 |
| 写法 | const img = require('路径') | import img from '路径' |
| 静态分析 | 较难优化(不如 import 友好) | 更容易优化和 tree-shaking(删除未使用代码) |
| 动态加载 | 支持动态路径 | 需要特殊写法 import() |

建议:

1、新项目尽量用 import 更现代,性能更好;

2、旧项目或 Node.js 环境可以用 require;

3、注意:纯浏览器环境不能直接使用 require,需要 webpack 等工具;

两种方式在 webpack / vite 等工具中最终效果是一样的,只是写法不同

相关推荐
执风挽^18 分钟前
Python基础编程题2
开发语言·python·算法·visual studio code
梦帮科技18 分钟前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
Z9fish27 分钟前
sse哈工大C语言编程练习20
c语言·开发语言·算法
VT.馒头1 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
萧鼎1 小时前
Python 包管理的“超音速”革命:全面上手 uv 工具链
开发语言·python·uv
css趣多多1 小时前
一个UI内置组件el-scrollbar
前端·javascript·vue.js
-凌凌漆-1 小时前
【vue】pinia中的值使用 v-model绑定出现[object Object]
javascript·vue.js·ecmascript
C澒1 小时前
前端整洁架构(Clean Architecture)实战解析:从理论到 Todo 项目落地
前端·架构·系统架构·前端框架
Anastasiozzzz1 小时前
Java Lambda 揭秘:从匿名内部类到底层原理的深度解析
java·开发语言
刘琦沛在进步1 小时前
【C / C++】引用和函数重载的介绍
c语言·开发语言·c++