【问题标题】:Javascript: A dictionary of functions; one function in dictionary calls anotherJavascript:函数字典;字典中的一个函数调用另一个函数
【发布时间】:2019-09-24 14:34:20
【问题描述】:

我有一个函数字典,它们本质上是对我用来接收数据的 API 的不同调用(在承诺中)。我的 API 构建数据的方式,为了从每个国家/地区获取每个物种,我必须使用特定于每个国家/地区的关键字 q 调用修改 https 请求的 API。我在字典中创建了一个名为sp_b_c 的函数,这意味着按国家/地区划分的物种。它需要一个q,即国家/地区,调用本身返回一个具有该国家内所有物种的承诺值的承诺。

我想在字典中创建另一个函数,它可以让我从每个国家/地区获取所有物种,以便将其全部包含在内以供以后使用。

我试图做的是创建一个名为sp_b_c_all 的新函数。我在字典中调用我的country_list 函数以获取所有国家/地区。然后我遍历每个国家并将每个国家传递给函数sp_b_c。我创建了一个数组sp_b_c_entire,它本质上就像一个Promise.all,因为通过遍历国家并将每个国家传递给sp_b_c 的调用所收到的所有承诺都会返回一个承诺。

但是,在拨打此电话getData("accesses", "sp_b_c_all")] 时, 我收到以下错误:

script.js:38 Uncaught TypeError: country_li.then is not a function
    at Object.accesses.sp_b_c_all (script.js:38)
    at getData (script.js:68)
    at initialization (script.js:194)
    at script.js:365

下面是引用的代码:

var getData = function(set, target, q, ...manyMore) {
  var pack = [];
  // ~ USE rest parameters instead, grab array from ...

  // set accesses
  var api_token = "9d34bf3f79ae6a8b88c4f1f54ffc3e64e5f4cdcc2cc47bd1cf429e7e247d94b2";
  var accesses = new Object();
  var alternative = new Object();

  // ~ do a promise all, might be overload for API, so limitations
  if (set == "accesses") {
   accesses.sp_b_c = function(q) {
     return d3.json("https://apiv3.iucnredlist.org/api/v3/country/getspecies/"+ q +
     "?token=9d34bf3f79ae6a8b88c4f1f54ffc3e64e5f4cdcc2cc47bd1cf429e7e247d94b2")
     .then(function(d) { return d; });
   }

   accesses.sp_b_c_all = function() {
     sp_b_c_entire = [];
     console.log(accesses.sp_b_c("AE"))
     var country_li = accesses.country_list;
     country_li.then(function(countries) {
       console.log(countries);
       countries.forEach(function(country) {
         sp_b_c_entire.push(accesses.sp_b_c(country));
       })
    })
    return sp_b_c_entire;
  }

   accesses.country_list = function() {
     return d3.json("https://apiv3.iucnredlist.org/api/v3/country/list?token="+api_token)
              .then(function(d) { return d; });
   }
   accesses.comp_group_list = function() {
     return d3.json("https://apiv3.iucnredlist.org/api/v3/comp-group/list?token="+api_token)
              .then(function(d) { return d; });
   }
   accesses.comp_group_specific = function() {
     return d3.json("https://apiv3.iucnredlist.org/api/v3/comp-group/getspecies/"+ key +"?token="+api_token)
              .then(function(d) { return d; });
   }
   accesses.threats_regional = function() {
     return d3.json("http://apiv3.iucnredlist.org/api/v3/threats/species/name/Ursus%20maritimus/region/europe?token="+api_token)
              .then(function(d) { return d; });
   }
   accesses.threats_global = function() {
     return d3.json("http://apiv3.iucnredlist.org/api/v3/threats/species/name/Loxodonta%20africana?token="+api_token)
              .then(function(d) { return d; });
   }

   return accesses[target]();
 }
  // alternative threat dataset
  else if (set == "csv") {
    var data = d3.csv(target + ".csv");
    var transformation = data.then(
      function(d) {
        var container = d.map(function(d) {
        return {s_n: d.ScientificName,
                c_n: d.CommonName,
                state: d.States,
                group: d.group};
        });
        pack.push(container);
      } // end of anon/callback function
    ); // end of then function
  return data;
  } // end of else if conditional


};

我曾想过,如果我在accesses.sp_b_c_all 内拨打accesses.country_list,我会收到国家名单的承诺。然后我利用then() 访问承诺值。在then(countries) 内部,国家是数据集(国家列表。这是我利用forEach 循环遍历countries 中的每个国家/地区的地方,然后我将每个国家/地区传递给accesses.sp_b_c 的api 调用country 参数。由此,我希望收到一个 promise,然后将其存储在数组中。

我做错了什么,我该如何解决这个问题?也许我应该如何改变我的流程?

【问题讨论】:

    标签: javascript arrays function object ecmascript-6


    【解决方案1】:

    如果country_li是一个返回promise的函数,你需要先调用它来获得promise:

    country_li().then(function(countries) {...})
    

    【讨论】:

    • 所以说,accesses.country_li 我只是抓住了存储在其中的函数而没有调用它?
    • 是的,正是@MichaelRamage - typeof country_li == "function"
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2022-01-15
    • 1970-01-01
    • 2012-01-23
    • 2020-10-10
    • 1970-01-01
    • 2018-08-31
    • 1970-01-01
    相关资源
    最近更新 更多