react用useImages读取图片,方便backgroundImage

注意import.meta.glob中定义的文件夹路径,视情况而定,可能是assets或images

复制代码
import { useMemo } from "react";

export default function useImages() {
  // 扫描 images 目录及其子目录下的所有图片
  const modules = import.meta.glob('@/assets/**/*.{png,jpg,jpeg,svg}', { eager: true });

  const images = useMemo(() => {
    const map = {};
    Object.entries(modules).forEach(([path, mod]) => {
      // 提取相对路径,例如 icons/icon1.png
      const relativePath = path.split('/images/')[1];
      map[relativePath] = mod.default;
    });
    return map;
  }, [modules]);

  return images;
}

使用方法:

复制代码
import useImages from "@/hooks/useImages";

  const uimages = useImages()





<div style={{ backgroundImage: "url(" + uimages['bgred.png'] + ")" }}>

<img src={uimages['recommed.png']} className="w-7 ml-[10px]" />

例子:

相关推荐
巧克力芋泥包16 小时前
前端使用阿里云图形验证码;并且与安卓进行交互
android·前端·阿里云
星释16 小时前
Rust 练习册 75:ETL与数据转换
开发语言·rust·etl
happyjoey21716 小时前
使用Qt自带的Maintenance Tool将Qt6.9升级为QT6.10
开发语言·qt
G***E31617 小时前
前端GraphQLAPI
前端
lumi.17 小时前
Vue + Element Plus 实现AI文档解析与问答功能(含详细注释+核心逻辑解析)
前端·javascript·vue.js·人工智能
z***I39417 小时前
VueGraphQLAPI
前端
S***t71418 小时前
Vue面试经验
javascript·vue.js·面试
粉末的沉淀19 小时前
css:制作带边框的气泡框
前端·javascript·css
p***h64320 小时前
JavaScript在Node.js中的异步编程
开发语言·javascript·node.js
散峰而望20 小时前
C++数组(二)(算法竞赛)
开发语言·c++·算法·github