Base64 图片在 React Native 中无法显示
创始人
2024-11-25 06:00:33
0

在React Native中,要显示Base64图片,可以使用Image组件和source属性。然而,有时候直接将Base64字符串赋值给source属性可能无法正常显示图片。以下是一种解决方法:

  1. 首先,将Base64字符串转换为可用的图片资源。可以使用rn-fetch-blob库来实现此功能。确保你已经安装了该库,可以使用以下命令安装:
npm install rn-fetch-blob --save
  1. 在你的React Native组件中,导入rn-fetch-blob库,并使用fs.writeFile方法将Base64字符串写入临时文件:
import RNFetchBlob from 'rn-fetch-blob';

// ...

const saveImageToDisk = async (base64String, imageName) => {
  const fs = RNFetchBlob.fs;
  let imagePath = null;

  try {
    const base64Data = base64String.replace('data:image/jpeg;base64,', '');
    imagePath = `${fs.dirs.CacheDir}/${imageName}.jpg`;

    await fs.writeFile(imagePath, base64Data, 'base64');
  } catch (error) {
    console.error(error);
  }

  return imagePath;
};
  1. 在需要显示图片的地方,调用saveImageToDisk方法并使用返回的图片路径作为source属性的值:
import { Image } from 'react-native';

// ...

const YourComponent = () => {
  const base64Image = 'your_base64_image_string';
  const imageName = 'your_image_name';

  const displayImage = async () => {
    const imagePath = await saveImageToDisk(base64Image, imageName);
    return `file://${imagePath}`;
  };

  return (
    
  );
};

export default YourComponent;

通过这种方式,Base64图片将会被保存到设备的临时目录中,并将临时文件路径作为source属性的值传递给Image组件,从而正确显示Base64图片。

相关内容

热门资讯

记者揭秘!智星菠萝辅助(透视辅... 记者揭秘!智星菠萝辅助(透视辅助)拱趴大菠萝辅助神器,扑克教程(有挂细节);模式供您选择,了解更新找...
一分钟揭秘!约局吧能能开挂(透... 一分钟揭秘!约局吧能能开挂(透视辅助)hhpoker辅助靠谱,2024新版教程(有挂教学);约局吧能...
透视辅助!wepoker模拟器... 透视辅助!wepoker模拟器哪个好用(脚本)hhpoker辅助挂是真的,科技教程(有挂技巧);囊括...
透视代打!hhpkoer辅助器... 透视代打!hhpkoer辅助器视频(辅助挂)pokemmo脚本辅助,2024新版教程(有挂教程);风...
透视了解!约局吧德州真的有透视... 透视了解!约局吧德州真的有透视挂(透视脚本)德州局HHpoker透视脚本,必胜教程(有挂分析);亲,...
六分钟了解!wepoker挂底... 六分钟了解!wepoker挂底牌(透视)德普之星开辅助,详细教程(有挂解密);德普之星开辅助是一种具...
9分钟了解!wpk私人辅助(透... 9分钟了解!wpk私人辅助(透视)hhpoker德州透视,插件教程(有挂教学);风靡全球的特色经典游...
推荐一款!wepoker究竟有... 推荐一款!wepoker究竟有透视(脚本)哈糖大菠萝开挂,介绍教程(有挂技术);囊括全国各种wepo...
每日必备!wepoker有人用... 每日必备!wepoker有人用过(脚本)wpk有那种辅助,线上教程(有挂规律);wepoker有人用...
玩家必备教程!wejoker私... 玩家必备教程!wejoker私人辅助软件(脚本)哈糖大菠萝可以开挂,可靠技巧(有挂神器)申哈糖大菠萝...