本地反应支持 base64编码的图像吗?

是否反应本地支持基于64编码的图像?

我试过:

<Image source={{uri: ''}} style={styles.image}/>

但是它没有工作。我只是做错了还是没有得到支持?

125735 次浏览

我不认为这是支持的。除非 URL 包含“ http”或“ https”,否则它被认为是一个“静态”图像。通过选择代码,最终映像的实例化归结为:

if ([path isAbsolutePath]) {
image = [UIImage imageWithContentsOfFile:path];
} else {
image = [UIImage imageNamed:path];
if (!image) {
image = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:path ofType:nil]];
}
}

一步一步来:

  1. 如果 URL 是绝对路径,则将其作为文件加载
  2. 否则,如果图像被缓存(imageNamed) ,则加载
  3. 否则,如果图像是一个相对路径,则从 app bundle 加载它

显然这些都与 base64无关,我已经为这个特性创建了一个 pull 请求,您可以在这里查看:

Https://github.com/facebook/react-native/pull/576

我认为拉姆齐是错误的,反应本地有一个基地64图像的完全支持。 我找到了这个

https://facebook.github.io/react-native/docs/tabbarios.html

这是一个如何创建 iOS TabBarController 的官方示例,他们使用 base64图像作为 TabBar 的图标之一。

我认为您没有在 <Image/>style属性中指定 widthheight

我试过在我的“反应本土游乐场”中使用你的 base64映像,它很有效。

demo

用法

var base64Icon = '';

以这种方式使用

<Image style=\{\{width: 100, height: 50, resizeMode: Image.resizeMode.contain, borderWidth: 1, borderColor: 'red'}} source=\{\{uri: base64Icon}}/>

是的,它在支持

试试下面 它在 iOS 和以下版本中进行了测试 “反应”: “16.9.0” “反应原生”: “0.61.2”,

const base64Image = '...';
<Image source=\{\{uri: `data:image/jpeg;base64,${base64Image}`}} />

如果仍然不工作。检查图像类型,如 jpeg,png 等。

希望这个能帮上忙:)

 <Image
source=\{\{
uri: `data:image/jpeg;base64,${this.state.barcodeImage}`,
}}
style=\{\{height: 200, width: 250}}
/>

告示: 在图像中添加样式

   <Image
style=\{\{widht:"20" , height:"20%"}}
source=\{\{
uri: '',
}}
/>

如果出现图像不显示的问题,请尝试以某种状态保存图像的 base64,然后使用它

const [base64Image, setBase64Image] = useState<string>(BASE64DATA)


//... your code


<Image
source=\{\{
uri: `data:image/jpg;base64,${base64Image}`
}}
resizeMode="cover"
style={styles.profilePicture}
/>

重要: 进一步检查 URI 中的“ jpg”是否与您的图像扩展相同