亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

反應本機 FlatList 鍵

反應本機 FlatList 鍵

慕村9548890 2023-03-03 10:06:57
我有一個 FlatList,它呈現一個自定義組件“Card”。我作為 keyExtractor 傳遞這個函數:const keyExtractor = (item) => item.id;我的 renderItem 函數如下所示:const renderItem = ({item, index}) => <Card {...item} />我的問題是:我應該將密鑰傳遞給 Card 組件嗎?我的意思是,我應該這樣做嗎const renderItem = ({item, index}) => <Card key={item.id} {...item} />避免我的 flatlist 重新渲染組件并提高我的列表的性能?我見過有人這樣做……但我從來沒有這樣做過。如果答案是肯定的,那么如果每個呈現的組件都有一個密鑰,為什么我們需要 keyExtractor?當然,如果我將密鑰傳遞給我的自定義組件,我將在其實現時執行此操作:return <View key={props.key}>...</View>謝謝。
查看完整描述

1 回答

?
呼啦一陣風

TA貢獻1802條經驗 獲得超6個贊

您應該在數據中擁有一個獨特的屬性并將其用作鍵。無需將 傳遞key給您的Card組件。


如果你的數據是這樣的:


data = [

  {

    id: 'a12f56e5',

    name: 'me',

    age: 24

  }

  // ...

];

然后你可以使用id作為關鍵。


另外,請看一下這個以提高您的 FlatList 性能



查看完整回答
反對 回復 2023-03-03
  • 1 回答
  • 0 關注
  • 104 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號