首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从JSON只输出FlatList中的5个元素?反应本土化

如何从JSON只输出FlatList中的5个元素?反应本土化
EN

Stack Overflow用户
提问于 2022-07-02 09:43:35
回答 1查看 28关注 0票数 0

我有一个JSON文件,在这个文件中,新的新闻项目不断地被存储和添加,它们的数量在不断地变化。我只想将这个JSON文件中的最后3个元素输出到FlatList。该怎么做呢?

这是我的JSON收据和我的FlatList:

代码语言:javascript
复制
  const [isLoading, setLoading] = useState(true);
  const [data, setData] = useState([]);

  const getNewsMain = async () => {
    try {
      const response = await fetch(`https://cdn.ertil-gorod.ru/json/ertnews.json?nocache`);
      const json = await response.json();
      setData(json.ertnews);
    } catch (error) {
      console.error(error);
    } finally {
      setLoading(false);
    }
  }

  useEffect(() => {
      getNewsMain();
  }, []);

            <FlatList 

              data={data}
              initialNumToRender={5} 
              keyExtractor={({ id }, index) => id} 
              renderItem={ ( { item } ) => (

                <TouchableOpacity 

                  style={ styles.ert__news__item } 
                  onPress={ ( ) => navigation.navigate( 'FullNews', item ) }>  

                    <Image 
                      style={ styles.ert__image__news } 
                      source={ { uri: item.img } } 
                    />

                    <Text style={ styles.ert__title__news }>{ item.name }</Text>

                    <Text style={ styles.ert__anons__news }>{ item.anons }</Text>
                    
                </TouchableOpacity>

            )} />
EN

回答 1

Stack Overflow用户

发布于 2022-07-02 09:53:50

如果data是一个数组,则可以使用Array.slice

代码语言:javascript
复制
 <FlatList 
   data={data.slice(-3)}
   initialNumToRender={5} 
   keyExtractor={({ id }, index) => id} 
     renderItem={ ( { item } ) => (
       <TouchableOpacity 
         style={ styles.ert__news__item } 
         onPress={ ( ) => navigation.navigate( 'FullNews', item ) }>  
           <Image 
             style={ styles.ert__image__news } 
             source={ { uri: item.img } } 
           />
           <Text style={ styles.ert__title__news }>{ item.name }</Text>
           <Text style={ styles.ert__anons__news }>{ item.anons }</Text>
       </TouchableOpacity>
    )}
  />
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72838066

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档