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;
相关推荐
神秘代码行者6 分钟前
HTML Picture标签详细教程
前端·html
爱编程的鱼11 分钟前
如何用CSS实现HTML元素的旋转效果
前端·css
芭拉拉小魔仙32 分钟前
【Vue3/Typescript】合并多个pdf并预览打印,兼容低版本浏览器
javascript·typescript·pdf
HBR666_1 小时前
vue3定义全局防抖指令
前端·javascript·vue.js
前端老实人灬2 小时前
vue使用docx 生成 导出word文件。(包含:页眉、页脚、生成目录、页码、图片、表格、合并表格)
前端·vue.js·word
MyhEhud2 小时前
kotlin 过滤 filter 函数的作用和使用场景
android·java·服务器·前端·kotlin
苦夏木禾2 小时前
关于react19版本更新后部分组件无法正常使用的问题
javascript·react.js
光影少年2 小时前
vue中$set原理
前端·javascript·vue.js
codecodegirl2 小时前
实现在h5中添加日历提醒:safari唤起系统日历,其它浏览器跳转google日历
前端·javascript·vue.js·html5
Attacking-Coder2 小时前
前端面试宝典---webpack原理解析,并有简化版源码
前端·面试·webpack