React中引入使用本地图片

1、css样式中,可以写成如下:

复制代码
.login {
	// 映射路径
  background: url('@images/img-login.png');
  background-size: 100% 100%;
}
.box{
	// 相对路径
  background: url('../assets/images/box.png');
  background-size: 100% 100%;
}

2、在jsx文件中

复制代码
import LoginLogo1 from '@images/icon-login.png'; 
import LoginLogo2 from '../assets/images/icon-login.png';
const Login = () => {
	return (
		<div className="login-box">
       	 	<img src={LoginLogo1}  alt="" />
       	 	<img src={LoginLogo2}  alt="" />
     	 </div>
	);
};
export default Login;

3、如果使用require,使用webpack构建的项目中用法如下:

复制代码
<div className="form-title">
  <img src={require('../../assets/images/logo.png')} alt="" />
</div>

4、如果使用require,使用vite构建的项目中用法如下:

先安装插件:vite-plugin-require-transform
npm i vite-plugin-require-transform --save-dev

在vite.config.js中配置

复制代码
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react-swc'
import requireTransform from "vite-plugin-require-transform";  // 引入
export default defineConfig({
  plugins: [
    react(),
    // 配置
    requireTransform({
      fileRegex: /.js$|.jsx$/,
    })
  ]
})

在jsx文件中使用

复制代码
<div className="form-title">
  <img src={require('../../assets/images/logo.png')} alt="" />
</div>

5、在JSX文件中,想导入图片,不能直接写成:<img src="./logo.png">,因为打包后,项目结构会变化。

相关推荐
子兮曰4 小时前
Bun v1.3.14 深度解析:Image API、HTTP/3、全局虚拟存储与五十项变革
前端·后端·bun
kyriewen5 小时前
今天,百年巨头一次砍了9200人,而一个离职科学家的实话让全网睡不着觉
前端·openai·ai编程
问心无愧05135 小时前
ctf show web 入门42
android·前端·android studio
kyriewen5 小时前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u5 小时前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby6 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
天若有情6736 小时前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇6 小时前
前端转后端:SQL 是什么
前端
张元清7 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试
广州华水科技7 小时前
单北斗GNSS变形监测是什么?主要有怎样的应用与优势?
前端