为什么 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 等工具中最终效果是一样的,只是写法不同

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值