警告:道具类型失败:提供给“图像”的道具“来源”无效。我在一个对象中用 require() 保存了图像的路径
Warning: Failed prop type: Invalid prop `source` supplied to `Image`. I have saved path of the image with require() in an object
当我试图获取以 require() 作为属性存储为字符串的 js 对象中的图像路径时出现此错误。
Warning: Failed prop type: Invalid prop `source` supplied to `Image`.
CategoriesScreen.js
import React from "react";
import {
View,
Text,
FlatList,
StyleSheet,
TouchableOpacity,
} from "react-native";
import { CATEGORIES } from "../Data/Dummy-Data";
import CategoryGrid from "../component/categoryGrid";
const CategoriesScreen = (props) => {
const renderGridItem = (itemData) => {
return (
<CategoryGrid
title={itemData.item.title}
imgUrl={itemData.item.url}
//console.log (itemData.item.url)-> require(..) ->image path
onSelect={() =>
props.navigation.navigate({
routeName: "CategoryMeals",
params: {
categoryId: itemData.item.id,
},
})
}
></CategoryGrid>
);
};
return (
<View>
<FlatList data={CATEGORIES} renderItem={renderGridItem} numColumns={2} />
</View>
);
};
CategoriesScreen.navigationOptions = {
headerTitle: "Meals Categories",
};
const styles = StyleSheet.create({
screen: {
flex: 1,
justifyContent: "center",
alignItems: "center",
//this is unused till now.
},
});
export default CategoriesScreen;
这里我存储了所有图片的路径
虚拟-data.js
import Category from "../Models/category";
export const CATEGORIES = [
new Category("C1", "Italian", "require('../assets/Images/italian.jpeg')"),
new Category("C2", "Indian", "require('../assets/Images/Indian.jpeg')"),
new Category("C3", "French", "require('../assets/Images/French.jpeg')"),
new Category(
"C4",
"Hamburgers",
"require('../assets/Images/Hamburgers.jpeg')"
),
new Category("C5", "German", "require('../assets/Images/German.jpeg')"),
new Category("C6", "Asian", "require('../assets/Images/Asian.jpeg')"),
new Category("C7", "Breakfast", "require('../assets/Images/Breakfast.jpeg')"),
new Category("C8", "Dinner", "require('../assets/Images/Dinner.jpeg')"),
];
category.js
class Category {
constructor(id, title, url) {
this.id = id;
this.title = title;
this.url = url;
}
}
export default Category;
CategoryGrid.js
import React from "react";
import {
TouchableOpacity,
StyleSheet,
View,
Text,
ImageBackground,
} from "react-native";
const CategoryGrid = (props) => {
return (
<TouchableOpacity style={styles.gridItems} onPress={props.onSelect}>
<View>
<ImageBackground
source={props.imgUrl}
style={{ width: "100%", height: "90%" }}
/>
<Text>{props.title}</Text>
</View>
</TouchableOpacity>
);
};
const styles = StyleSheet.create({
gridItems: {
flex: 1,
margin: 15,
height: 150,
},
});
export default CategoryGrid;
console.log() 在 CategoriesScreen.js 和 categoryGrid.js 中说 -> require(../assests/Images/image.jpeg)
我正在尝试获取图像路径作为从 CategoryScreen.js 到 categoryGrid.js 的道具,它作为对象存储在 Dummy-Data.js.
中
知道我做错了什么吗?
这样做
<ImageBackground
source={{uri: props.imgUrl}}
style={{ width: "100%", height: "90%" }}
/>
import Category from "../Models/category";
export const CATEGORIES = [
new Category("C1", "Italian", require("../assets/Images/italian.jpeg")),
new Category("C2", "Indian", require("../assets/Images/Indian.jpeg")),
new Category("C3", "French", require("../assets/Images/French.jpeg")),
new Category("C4", "Hamburgers", require("../assets/Images/Hamburgers.jpeg")),
new Category("C5", "German", require("../assets/Images/German.jpeg")),
new Category("C6", "Asian", require("../assets/Images/Asian.jpeg")),
new Category("C7", "Breakfast", require("../assets/Images/Breakfast.jpeg")),
new Category("C8", "Dinner", require("../assets/Images/Dinner.jpeg")),
];
当我试图获取以 require() 作为属性存储为字符串的 js 对象中的图像路径时出现此错误。
Warning: Failed prop type: Invalid prop `source` supplied to `Image`.
CategoriesScreen.js
import React from "react";
import {
View,
Text,
FlatList,
StyleSheet,
TouchableOpacity,
} from "react-native";
import { CATEGORIES } from "../Data/Dummy-Data";
import CategoryGrid from "../component/categoryGrid";
const CategoriesScreen = (props) => {
const renderGridItem = (itemData) => {
return (
<CategoryGrid
title={itemData.item.title}
imgUrl={itemData.item.url}
//console.log (itemData.item.url)-> require(..) ->image path
onSelect={() =>
props.navigation.navigate({
routeName: "CategoryMeals",
params: {
categoryId: itemData.item.id,
},
})
}
></CategoryGrid>
);
};
return (
<View>
<FlatList data={CATEGORIES} renderItem={renderGridItem} numColumns={2} />
</View>
);
};
CategoriesScreen.navigationOptions = {
headerTitle: "Meals Categories",
};
const styles = StyleSheet.create({
screen: {
flex: 1,
justifyContent: "center",
alignItems: "center",
//this is unused till now.
},
});
export default CategoriesScreen;
这里我存储了所有图片的路径
虚拟-data.js
import Category from "../Models/category";
export const CATEGORIES = [
new Category("C1", "Italian", "require('../assets/Images/italian.jpeg')"),
new Category("C2", "Indian", "require('../assets/Images/Indian.jpeg')"),
new Category("C3", "French", "require('../assets/Images/French.jpeg')"),
new Category(
"C4",
"Hamburgers",
"require('../assets/Images/Hamburgers.jpeg')"
),
new Category("C5", "German", "require('../assets/Images/German.jpeg')"),
new Category("C6", "Asian", "require('../assets/Images/Asian.jpeg')"),
new Category("C7", "Breakfast", "require('../assets/Images/Breakfast.jpeg')"),
new Category("C8", "Dinner", "require('../assets/Images/Dinner.jpeg')"),
];
category.js
class Category {
constructor(id, title, url) {
this.id = id;
this.title = title;
this.url = url;
}
}
export default Category;
CategoryGrid.js
import React from "react";
import {
TouchableOpacity,
StyleSheet,
View,
Text,
ImageBackground,
} from "react-native";
const CategoryGrid = (props) => {
return (
<TouchableOpacity style={styles.gridItems} onPress={props.onSelect}>
<View>
<ImageBackground
source={props.imgUrl}
style={{ width: "100%", height: "90%" }}
/>
<Text>{props.title}</Text>
</View>
</TouchableOpacity>
);
};
const styles = StyleSheet.create({
gridItems: {
flex: 1,
margin: 15,
height: 150,
},
});
export default CategoryGrid;
console.log() 在 CategoriesScreen.js 和 categoryGrid.js 中说 -> require(../assests/Images/image.jpeg)
我正在尝试获取图像路径作为从 CategoryScreen.js 到 categoryGrid.js 的道具,它作为对象存储在 Dummy-Data.js.
中知道我做错了什么吗?
这样做
<ImageBackground
source={{uri: props.imgUrl}}
style={{ width: "100%", height: "90%" }}
/>
import Category from "../Models/category";
export const CATEGORIES = [
new Category("C1", "Italian", require("../assets/Images/italian.jpeg")),
new Category("C2", "Indian", require("../assets/Images/Indian.jpeg")),
new Category("C3", "French", require("../assets/Images/French.jpeg")),
new Category("C4", "Hamburgers", require("../assets/Images/Hamburgers.jpeg")),
new Category("C5", "German", require("../assets/Images/German.jpeg")),
new Category("C6", "Asian", require("../assets/Images/Asian.jpeg")),
new Category("C7", "Breakfast", require("../assets/Images/Breakfast.jpeg")),
new Category("C8", "Dinner", require("../assets/Images/Dinner.jpeg")),
];