React 中图片请求失败使用裂图

复制代码
import React, { useState } from 'react';

const ImageWithFallback = ({ src, fallbackSrc }) => {
  const [imageSrc, setImageSrc] = useState(src);

  const handleImageError = () => {
    setImageSrc(fallbackSrc);
  };

  return <img src={imageSrc} onError={handleImageError} alt="加载失败" />;
};

export default ImageWithFallback;

在这个示例中,我们创建了一个名为 ImageWithFallback 的组件,它接受两个属性 srcfallbackSrc,分别表示要显示的图片地址和加载失败时要显示的默认图片地址。组件内部使用 useState 钩子来维护当前要显示的图片地址,然后使用 onError 事件处理程序来捕获图片加载失败的情况,并在发生错误时更新图片地址为默认图片地址。

你可以在需要显示图片的地方使用这个组件,并传入相应的 srcfallbackSrc 属性:

复制代码
Codeimport React from 'react';
import ImageWithFallback from './ImageWithFallback';

const App = () => {
  const imageUrl = 'https://example.com/image.jpg';
  const defaultImageUrl = 'https://example.com/default-image.jpg';

  return <ImageWithFallback src={imageUrl} fallbackSrc={defaultImageUrl} />;
};

export default App;
相关推荐
wuk9985 小时前
实现ROS系统的Websocket传输,向Web应用推送sensor_msgs::Image数据
前端·websocket·网络协议
合作小小程序员小小店7 小时前
web网页开发,在线%考试管理%系统,基于Idea,vscode,html,css,vue,java,maven,springboot,mysql
java·前端·系统架构·vue·intellij-idea·springboot
天天进步20158 小时前
CSS Grid与Flexbox:2025年响应式布局终极指南
前端·css
Boop_wu8 小时前
[Java EE] 计算机基础
java·服务器·前端
Novlan19 小时前
TDesign UniApp 组件库来了
前端
用户47949283569159 小时前
React DevTools 组件名乱码?揭秘从开发到生产的代码变形记
前端·react.js
顾安r10 小时前
11.8 脚本网页 打砖块max
服务器·前端·html·css3
倚栏听风雨10 小时前
typescript 方法前面加* 是什么意思
前端
狮子不白10 小时前
C#WEB 防重复提交控制
开发语言·前端·程序人生·c#