Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/396.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 我能';t从query.find()获取数据。然后(函数(结果)它似乎只是本地的_Javascript_React Native_Parse Platform - Fatal编程技术网

Javascript 我能';t从query.find()获取数据。然后(函数(结果)它似乎只是本地的

Javascript 我能';t从query.find()获取数据。然后(函数(结果)它似乎只是本地的,javascript,react-native,parse-platform,Javascript,React Native,Parse Platform,我无法获取flatListData,因为它似乎只是本地数据 我可以在query.find()中获取平面列表数据。然后(函数(结果) 除此之外,我一个也没有 我尝试使用Async/Await,但都不起作用 const W = Parse.Object.extend("W"); const query = new Parse.Query(W); var flatListData = []; query.find().then(function(results) { for (var i=0; i

我无法获取flatListData,因为它似乎只是本地数据 我可以在query.find()中获取平面列表数据。然后(函数(结果) 除此之外,我一个也没有

我尝试使用Async/Await,但都不起作用

const W = Parse.Object.extend("W");
const query = new Parse.Query(W);
var flatListData = [];

query.find().then(function(results) {
for (var i=0; i < results.length; i++){
flatListData.push(String(results[i].get("AlphabetCode")));
}

  alert(flatListData) //{"a" , "b" , "s" , "w"}

 });

 alert(flatListData) // Nothing! 
module.exports = flatListData;
const W=Parse.Object.extend(“W”);
constquery=newparse.query(W);
var flatListData=[];
query.find().then(函数(结果){
对于(var i=0;i
这里的问题是您试图生成一个异步导出语句,这是严格禁止的

首先,是的,
flatListData
全局的,而不是局部范围的。您面临的实际问题是,虽然查询结果有效地提供给了变量,但作为异步函数需要一些时间才能完成。当您在第二个
警报()中调用变量时
,并且在您的
模块.exports
中,您的异步查询尚未完成,因此未分配新的值,您最终只向外部脚本发送
未定义的

现在唯一可能的处理方法是强制您的
模块.exports
等待分配变量,这意味着要么在您的承诺范围内对变量进行限定(以及您的第一个
alert()
),要么使用
wait
语句。但是:

wait运算符用于等待承诺。它只能在异步函数中使用

就是这样。您唯一的退出路径是确定
模块的范围。导出
…这是完全禁止的。您永远不希望在顶级(也称为全局范围)之外调用导出

重新定义问题

您的目标是导出对象中的内容集,以便从多个位置使用

但请记住,您不能异步导出任何内容。在您的情况下,您唯一的选择是导出函数,并在需要值时调用它

现在是解决方案

getFlatListData.js,或任何你称之为它的东西

现在,在您的外部脚本中:

main.js,或者别的什么

这里可以做很多改进,比如使用
map()
函数分配
flatListData
,或者在处理任何错误的承诺中添加
reject


永远不要进行异步导出,如果必须这样做,这意味着您需要重新思考您的代码!

谢谢,它非常有用!!或者,您可以导出承诺,而不是导出返回承诺的函数。我不一定同意在加载脚本时运行进程,但我我想我会提到它,因为它稍微接近原始代码。
// Those are globally scoped. They will only be calculated on
// initialization, and not during outside import calls
const W = Parse.Object.extend("W");
const query = new Parse.Query(W);

// We wrap everything inside an async function, which will be exported
function getFlatListData() {
  // We return a promise, to allow outer calls to the result
  return new Promise(resolve => {
    // Also, avoid var. If you need a variable which isn’t constant, prefer let.
    let flatListData = [];

    // Prefer arrow functions here
    query.find().then(results => {
      // Works like your classic for(…) loop, but more efficient
      for(const result of results) {
        flatListData.push(String(result.get("AlphabetCode")));
      }

      // Resolve your function and send the result back
      resolve(flatListData);
    });
  });
}

module.exports = getFlatListData;
// Assuming you are using commonJS syntax
const getFlatListData = require(‘path_to_your_script/getFlatListData’);

[. . .]

getFlatListData().then(result => {
  // Now you can use your FlatListData aliased as result
});

// OR

const myAsyncFunction = async() => {
  const myVariable = await getFlatListData();

  // Use myVariable as you please now
};