react+ts 使用webp格式的图片处理

需求:

公司官网大图内存较大加载很慢,于是用webp格式的图片来替换原来的图片,在React项目中,如果你使用的是Create React App(CRA)或Webpack进行项目构建,遇到的常见错误原因可能涉及以下几点:

1.路径问题:使用require和相对路径需要确保路径正确且文件存在。

2.文件扩展名支持:确保项目配置正确支持特定格式的文件(如.webp)。

3.静态资源引用:有时使用require引入图片在现代React代码中通常会使用import语法。

我们逐一来看看可能的解决方法:
解决方法1:检查路径是否正确

确保我们的文件路径@/assets/images是正确的。例如,@符号通常是路径别名,需要确保webpack.config.js或者适用的配置文件有正确的别名设置。
解决方法2:使用import语法

通常我们会使用ES6的import语法来引入图片:

javascript 复制代码
import React from 'react';
import { animated } from 'some-animation-library';
import animateBg from './path-to-animateBg';
import bgImage from '@/assets/images/bg/bg_xx.webp'; // 使用实际可用的别名或相对路径

const MyComponent = () => {
  return (
    <animated.img
      src={bgImage}
      alt="背景"
      className="first-item__img"
      style={animateBg}
    />
  );
};

export default MyComponent;

解决方法3:配置WebPack支持.webp文件

使用了新的文件格式如.webp,一定要确保Webpack配置文件支持这种格式:

先查看package.json文件是否存在url-loader,如果没有就使用命令:

npm install --save url-loader

如果有的话就在webpack.config.js的配置添加

javascript 复制代码
 module: {
    rules: [
      {
          test: [/\.bmp$/, /\.gif$/, /\.jpe?g$/, /\.png$/, /\.webp$/],
          loader: require.resolve("url-loader"),
          options: {
             limit: imageInlineSizeLimit,
             name: "static/media/[name].[hash:8].[ext]"
             }
            },
      // 其他 loader规则 ...
    ],
  },
相关推荐
jt君424261 小时前
React Native JSI 深入剖析 — 第 5 部分中文技术整理:用 HostObject 把 C++ 类暴露给 JavaScript
前端·react native
胡萝卜术1 小时前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试
fluffyox1 小时前
Notion 的公式栏里,藏着一台虚拟机——逆向 + 用 600 行 JS 复刻它的编译器与栈式 VM
前端
kyriewen2 小时前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
猩猩程序员3 小时前
零基础学习 React 19
react.js
JouYY4 小时前
简单聊一下Harness层中的人机协同(HITL)
前端框架·llm·agent
Csvn5 小时前
Monorepo 迁移血泪史:从 Multi-Repo 到 Turborepo,这 3 个坑我帮你踩完了
前端
星栈5 小时前
Dioxus 多页面怎么做:`dioxus-router`、嵌套路由、`Outlet` 和页面组织,一篇给你讲顺
前端·rust·前端框架
用户987409238875 小时前
用 Remotion + edge-tts 打造中文教学视频全自动流水线
前端
风骏时光牛马5 小时前
Less前端工程化实战:变量混合器与项目样式分层落地
前端