我正在使用控制器中的此代码创建一个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
这是纯粹的风格偏好。我喜欢使用符号而不是字符串。