我正在使用控制器中的此代码创建一个Rails应用程序以调用API-我最初调用inventories endpoint,然后分别调用另外两个id端点store_id, product_id,以获取链接到清单的特定数据。这些数据被传递到一个散列,该散列变成“ @inventories /转换结果”:

class InventoriesController < ApplicationController
 def index
 response = Typhoeus.get("http://lcboapi.com/inventories")
 parsed_json = JSON.parse(response.body)

transformed_results = []

parsed_json["result"].each do |inventory|
  transformed_results.push(
    {
      product_name: product_lookup(inventory["product_id"]),
      store_name: store_lookup(inventory["store_id"]),
      quantity: inventory["quantity"],
    }
  )
end

@inventories = transformed_results
end
  private

  def store_lookup(store_id)
  response = Typhoeus.get("http://lcboapi.com/stores/#{store_id}")
    parsed_json = JSON.parse(response.body)
  return parsed_json["result"]["name"]
end

 def product_lookup(product_id)
 response = Typhoeus.get("http://lcboapi.com/products/#{product_id}")
     parsed_json = JSON.parse(response.body)
 return parsed_json["result"]["name"]
 end
end


我的问题是如何最好地通过AJAX将json哈希值转换为可以通过的形式并在Assets / javascript中进行迭代。

我知道我可以将其构建到视图(html.erb)中,并且已经做到了,但是我想使数据与DOM元素进行交互。

注意:我尝试做一个简单的控制台日志,以在控制台中显示json数据作为测试,但没有响应。在对React感到满意之前,我可以使用jQuery,但是我不确定如何从'assets / javascript / inventories.js'中获取@inventories数据-例如,如果我想从csv中获取某些内容我将使用以下数据库,但在这种情况下,数据库并不存在:

document.addEventListener('DOMContentLoaded', function () {
  console.log("ready!");
  $.ajax({
url: "/inventories",
method: "GET"
 }).done(function(data){
    var products = []
    data.forEach(function(item){
      products.push(item.product_name).toString();
      console.log(products);
    });
  });

})

最佳答案

在您的一个js文件(在assets/javascript中)中,您需要执行以下操作:

storeLookupResults = $.ajax({
  url: "/inventories.js",
  type: 'GET'
})
storeLookupResults.success (data) =>
  # do stuff with your results
  # 'data' will contain your json


注意:我已经编好了路线,所以您需要确保使用真实的路线

然后,在您的InventoriesController中,将index修改为:

def index
  response = Typhoeus.get("http://lcboapi.com/inventories")
  parsed_json = JSON.parse(response.body).with_indifferent_access

  @inventories = parsed_json[:result].map do |inventory|
    {
      product_name: product_lookup(inventory[:product_id]),
      store_name: store_lookup(inventory[:store_id]),
      quantity: inventory[:quantity],
    }
  end

  respond_to do |format|
    format.html
    format.json {render json: @inventories, status: :ok}
  end

end


请注意,.map返回一个array。因此,您不必做:

transformed_results = []

parsed_json["result"].each do |inventory|
  transformed_results.push(
    {
      product_name: product_lookup(inventory["product_id"]),
      store_name: store_lookup(inventory["store_id"]),
      quantity: inventory["quantity"],
    }
  )
end

@inventories = transformed_results


还要注意我做了:

parsed_json = JSON.parse(response.body).with_indifferent_access


这是纯粹的风格偏好。我喜欢使用符号而不是字符串。

09-11 17:39
查看更多