android - React Native Image uri 不起作用

标签 android react-native react-native-image

我试图显示本地文件中的图像,所以我尝试这样做

<Image 
    source={{uri:'../../assets/img_src/BTI.jpg'}}
    style={{height:150,width:150}}
/>

我的容器组件似乎获得了高度和宽度,但图像没有加载。所以我试试这个

<Image 
    source={require('../../assets/img_src/BTI.jpg')}
    style={{height:150,width:150}}
/>

它工作得很好,不幸的是,据我所知,如果我想先操作地址文件并将其存储到变量中,我不能使用这个实现。 示例:

const imgSrc = `../../assets/${data.image}`;

其中 data.image = 'img_src/BTI.jpg'。 我尝试在 android studio 中删除我的 android 模拟器上的所有数据,但结果仍然相同。难道我做错了什么?有没有更好的实现方式?

非常感谢:)

最佳答案

无法require() 动态路径是 React Native 的预期行为,打包器需要提前知道路径 - 参见 React Native issues

我们在项目中遇到了这个问题,我们将图像 URL 存储在我们的数据库中,并希望在应用程序中连接字符串以获取本地存储图像的路径。正如您所发现的,这是行不通的。您可能会发现我们的解决方法很有用。

在我们的 /images 文件夹中,我们创建了一个新的 images.js 文件,它只是导出一个对象,其键映射到我们所有的本地镜像路径,就像这样

  export const Images = {
    image1: require('./image1.png'),
    image2: require('./image2.png'),
    image3: require('./image3.png'),
  };

现在包装商提前知道所有路径并且很高兴。然后我们将 imageKey 添加到 DB 项并使用它而不是绝对路径。为了抓取图像,我们简单地做了

import { Images } from '../images/images';
// get your image key e.g. passed down through props
const img = Images[imageKey];

...
render() {
    ...
    <Image source={img} />
    ...
}

可能不适合您的确切用例,但希望您可以使用它。

关于android - React Native Image uri 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43050468/

相关文章:

image - React Native Image resizeMode vs resizeMethod

android - 如何使android全屏 Activity 中的操作栏始终可见

java - 另一个线程的监听器

java - AsyncTask onPostExecute 错误中的新 Intent

react-native - 安卓 'react-native-gesture-handler' 错误

react-native - 使用 react-native 裁剪图像

android - 无法让程序在 Android 上执行

ios - 运行命令 "xcodebuild"已退出,错误代码为 65

javascript - 如何使任何子组件在 React Native 中变得模糊?

ios - 我如何在 ios 上将 react-native 主题更改为 transaperent