javascript - 尝试从本地 JSON 文件调用图像时不会加载图像
问题描述
我能够从我在 RN 中创建的本地 JSON 文件动态引入数据。但是,当我返回并为每个配置文件插入一个图像以便它可以与他们的配置文件信息一起动态显示时,该应用程序中断说“该组件不能包含子项。如果您想在图像顶部呈现内容,请考虑使用”。
我已经为所有配置文件使用了背景,所以我真的不明白它在说什么,因为我在 JSON 文件中输入的图像将是每个字符的配置文件图像。我是否遵循正确的格式来调用图像?任何帮助,将不胜感激。
这就是我设置 JSON 文件的方式:
const characters = [
{ id: "1", name: "Homer Simpson", occupation: "Nuclear Safety Inspector",
url:
"https://assets.fxnetworks.com/cms/prod/shows/the-simpsons/photos/simpsons-sidebar/character-facts/Homer/swsb_character_fact_homer_288x763.png"
},
{ id: "2", name: "Marge Simpson", occupation: "Stay-at-home mom", url:
"https://assets.fxnetworks.com/cms/prod/shows/the-simpsons/photos/simpsons-sidebar/character-facts/Homer/swsb_character_fact_homer_288x763.png"},
{ id: "3", name: "Bart Simpson", occupation: "Student", url:
"https://assets.fxnetworks.com/cms/prod/shows/the-simpsons/photos/simpsons-sidebar/character-facts/Homer/swsb_character_fact_homer_288x763.png" },
{ id: "4", name: "Lisa Simpson", occupation: "Student", url:
"https://assets.fxnetworks.com/cms/prod/shows/the-simpsons/photos/simpsons-sidebar/character-facts/Homer/swsb_character_fact_homer_288x763.png" },
{ id: "5", name: "Maggie Simpson", occupation: "Baby", url:
"https://assets.fxnetworks.com/cms/prod/shows/the-simpsons/photos/simpsons-sidebar/character-facts/Homer/swsb_character_fact_homer_288x763.png" }
export default characters;
这就是我将其引入的方式:
import React from "react";
import {
View,
Text,
StyleSheet,
Image,
Button,
ImageBackground
} from "react-native";
class CharacterProfiles extends React.Component {
static navigationOptions = {
title: "The Simpsons",
headerStyle: {
backgroundColor: "#53b4e6"
},
headerTintColor: "#f6c945",
headerTitleStyle: {
fontWeight: "bold"
}
};
render() {
const { item } = this.props.navigation.state.params;
return (
<View>
<ImageBackground
source={{
uri:
"https://backgrounddownload.com/wp-content/uploads/2018/09/simpsons-clouds-background-5.jpg"
}}
style={{ width: "100%", height: "100%" }}
>
<Image>{item.url}</Image>
<Text>Name: {item.name}</Text>
<Text>Occupation: {item.occupation}</Text>
<Button
title="Character Directory"
onPress={() => this.props.navigation.navigate("CharacterDirectory")}
/>
<Button
title="Homepage"
onPress={() => this.props.navigation.navigate("Home")}
/>
</ImageBackground>
</View>
);
}
}
export default CharacterProfiles;
解决方案
与您已经对ImageBackground
组件完成的方式相同,您需要使用该source
属性来分配Image
. 你可以在 React Native 的Image 组件文档中看到更详细的例子。
<Image
source={{uri: item.url}}
/>
将标签内容中的源 URL<Image>
作为文本包含在内将无效。这样做基本上等同于在 HTML 中编写以下内容:
<img>https://example.com/myImage.png</img>
您会收到关于将内容放在图像顶部的警告,因为 React Native 认为您正在尝试将 URL作为文本叠加在图像上。由于 HTML<img>
元素不能做到这一点,Image
组件也不能。
推荐阅读
- splunk - 如何从值字段中减去一个字符串
- docker - Apache Ignite 缓存为空,表有值
- sql - 如何在 Microsoft Access 中组合由斜杠分隔的多个行
- wordpress - 如何在wordpress中通过分类法连接附件和用户
- javascript - 根据项目中的要求,将 json 对象数组解析为特定格式的 json 数组
- ios - 是否可以将应用商店中的应用程序切换为私有(企业)?
- apache-kafka-streams - 使用 Kafka Stream DSL 写入处理器中的主题
- python - 重新采样 Pandas 数据框无效
- html - 多个浏览器中的按钮位置放置问题
- ios - 如何在 Firestore Swift 中创建空集合