如何从 JSON 文件中随机获取并将其呈现为 FlatList?

Posted

技术标签:

【中文标题】如何从 JSON 文件中随机获取并将其呈现为 FlatList?【英文标题】:How to randomly fetch from a JSON file and render it into a FlatList? 【发布时间】:2019-11-29 02:03:49 【问题描述】:

我有一个从 JSON 文件中获取数据的应用程序。问题是,它从上到下获取数据。我希望它在 JSON 文件中随机获取。我将如何实现这一目标?

这就是我获取 JSON 的方式:

componentDidMount() 
    const url = ''
    this.setState( isLoading: true );  
    fetch(url)
    .then((response) => response.json())
    .then((responseJson) => 
      this.setState(
        dataSource: responseJson.product,
        dataBackup: responseJson.product,
        isLoading: false
      );
      )
    .catch((error) => 
      console.log(error)
    )
  

【问题讨论】:

数据的内容类型是什么?数组? 是的,没错 【参考方案1】:

当您阅读文件时,无法更改内容的顺序。 但是,一旦解析了 json,由于您的 product 键是一个数组,因此您可以在设置状态时打乱这个数组。

您可以使用此答案中的随机播放功能 How to randomize (shuffle) a javascript array?

或者,如果您使用 lodash,则有 shuffle 函数用于集合: https://lodash.com/docs/4.17.14#shuffle

你的最终代码是:

// import shuffle function from linked anwser,
// or with lodash :
import  shuffle  from "lodash";

// ...

componentDidMount() 
  const url = "";
  this.setState( isLoading: true );
  fetch(url)
    .then(response => response.json())
    .then(responseJson => 
      this.setState(
        dataSource: shuffle(responseJson.product),
        dataBackup: responseJson.product,
        isLoading: false
      );
    )
    .catch(error => 
      console.log(error);
    );

【讨论】:

以上是关于如何从 JSON 文件中随机获取并将其呈现为 FlatList?的主要内容,如果未能解决你的问题,请参考以下文章

无法将 API JSON 数据呈现到 vue js 中的表

如何从 json 中获取 int 并将其解析为 dart 中的 bool?

如何从函数内部获取 JSON 数据并将其快速显示在文本字段上?

如何从 Spotify Search API 获取数据并将其解析为 JSON? [在 node.js 中

如何保存从Kinect 2.0收集的Body数据并将其保存在JSON文件中?

如何在 JQuery 表单构建器中使用 JSON 呈现表单