Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
2.4k views
in Technique[技术] by (71.8m points)

How to map array in flatlist in React Native

I have functionality which will return me days of the week. Then I am mapping that array into ScrollView. I am able to do this succesfully.

Below is my code:

<ScrollView
  horizontal={true}
  showsHorizontalScrollIndicator={false}>
  {weekArray.map((item, index) => (
    <TouchableOpacity
      index={index}
      onPress={() => setIndexSelect(index)}
      key={index}>
      <Text>
        {index === weekArray.length - 1 ? ` ${item.day} ` : ` ${item.day} | `}
      </Text>
    </TouchableOpacity>
  ))}
</ScrollView>;

This works, But I wanted to do this using FlatList, so tried below given code:

 <FlatList
  horizontal={true}
  contentContainerStyle={styles.horizontalView}
  data={weekArray}
  renderItem={_renderItem}
  keyExtractor={(item) => item.day}
/>;

const _renderItem = (item, index) => {
    <TouchableOpacity
      index={index}
      onPress={() => setIndexSelect(index)}
      key={index}
    >
      <Text>
        {index === weekArray.length - 1 ? ` ${item.day} ` : ` ${item.day} | `}
      </Text>
    </TouchableOpacity>
  }

I am getting just blank screen with this code. I am very new to using FlatList , so I am not able to figure out how to do this.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

To use Flatlist, simply you have to pass data which you want to map, and there's a renderItem prop which is used for rendering the data, there's another prop called keyExtractor which is for giving every element a unique

<Flatlist 
   data={weekArray}
   renderItem={_renderItem}
   keyExtractor={(item) => item.day}
/>

const _renderItem = ({item, index}) => {
   return (
     //your jsx/code goes here
)}

for renderItem you have to add {}.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...