[英]React native component not updating its state while rendering
I am trying to render single book one by one from redux when click on next book button.当单击下一本书按钮时,我正在尝试从 redux 中逐一呈现单本书。 I achieved it by using below code but issue is when i try to add some book in bookmarks and click on next book then next book star also showed as orange (which is bookmarked state).我通过使用下面的代码实现了它,但问题是当我尝试在书签中添加一些书并单击下一本书然后下一本书星也显示为橙色(这是书签状态)。 I also tried to make a bookmark btn code as a component so that its current state wont show in the next book but its still showing.我还尝试将书签 btn 代码作为组件,以便其当前的 state 不会在下一本书中显示,但仍会显示。 How can i overcome this issue.我该如何克服这个问题。 Images of issue are attached.附上问题图片。 bookmarked state normal state书签 state正常 state
const renderBooks = totalBooks?.books?.length && totalBooks?.books[bookIndex] && <View>
<View style={styles.spaceBetween}>
<TouchableOpacity onPress={() => navigation.goBack()}><AntDesign name="arrowleft" size={28} color="#0b466b" /></TouchableOpacity>
<Bookmark
book={totalBooks?.books[bookIndex]}
/>
</View>
<ImageBackground source={totalBooks?.books[bookIndex].cover ? {uri: totalBooks?.books[bookIndex].cover} : BookCover} style={styles.bookCover}>
</ImageBackground>
<Text style={styles.bookTitle}>{totalBooks?.books[bookIndex].title}</Text>
<ScrollView style={styles.bookDescriptionContainer} contentContainerStyle={{flexGrow: 1}}>
<Text style={styles.bookDescription}>
Lorem Ipsum is not simply random text.
</Text>
</ScrollView>
<View style={styles.actionBtnsContainer}>
<TouchableOpacity onPress={() => setOptionsPopUp(true)}>
<Text style={styles.buyItBtn}>Buy it</Text>
</TouchableOpacity>
<TouchableOpacity onPress={() => nextBook()}>
<Text style={styles.readItBtn}>Next Book</Text>
</TouchableOpacity>
</View>
<View>
const [addToBookmark, setAddToBookmark] = useState(false);
const handleBookmarks = () => {
const myBookmark = addToBookmark;
setAddToBookmark(!myBookmark)
if(!myBookmark) {
console.log('Add')
addInBookmarks(book)
} else {
console.log('remove')
removeFromBookmarks(book)
}
}
useEffect(() => {
}, [addToBookmark])
return(
<TouchableOpacity onPress={handleBookmarks}>
<AntDesign name={addToBookmark ? "star" : "staro"} size={24} color={addToBookmark ? "#ff910c" : "#0b466b"} />
</TouchableOpacity>
);
In the function nextBook()
you can try set the state of setAddToBookmark(false)
or if the book as been marked the state could be set to false or true dependig your data在 function nextBook()
中,您可以尝试将setAddToBookmark(false)
的 state 设置为,或者如果这本书被标记为 state,则可以将您的数据设置为 false 或 true
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.