2010-12-08 111 views
0

我有以下的控制器代码:Ruby on Rails的 - JSON格式

def calculate_quote 

    @mouldings = Moulding.find(params[:id].split(","), :select => 'id, cost, width') 
    @mouldings.collect! do |moulding| 
    { "moulding_id_#{moulding.id}" => { :cost => moulding.cost, :width => moulding.width } } 
    end 
    @material_costs = MaterialCost.all 
    @material_costs.collect! do |material_cost| 
    { material_cost.material.gsub(" ", "_").downcase => { :cost => material_cost.cost_per_square_mm } } 
    end 
    @app_options = AppOption.all 
    @app_options.collect! do |app_option| 
    { app_option.name.gsub(" ", "_").downcase => { :value => app_option.value } } 
    end 

    respond_to do |format| 
    format.json { render :json => { :mouldings => @mouldings, :material_costs => @material_costs, :app_options => @app_options } } 
    end 
end 

而这给了我下面的JSON输出:

{"mouldings":[{"moulding_id_2":{"cost":"3.1","width":45}},{"moulding_id_4":{"cost":"1.5","width":30}},{"moulding_id_6":{"cost":"2.1","width":50}}],"material_costs":[{"mountboard":{"cost":"0.00000246494303242769"}},{"glass":{"cost":"0.0000032426589803639"}},{"backing_board":{"cost":"0.00000135110790848496"}}],"app_options":[{"vat":{"value":"17.5"}},{"wastage":{"value":"20"}},{"markup":{"value":"3"}}]} 

我想格式化JSON输出,所以我可以使用jQuery使用以下语法来提取数据:

data.mouldings.moulding_id_2.cost 

如何更改控制器以实现这个?

回答

1

让我们尝试重新思考构建数据的方式。在我看来,使用ID作为对象索引并没有什么意义。相反,为什么不做这样的事情:

@mouldings = Moulding.find(params[:id].split(","), :select => 'id, cost, width') 
@mouldings.collect! do |moulding| 
    { :id => moulding.id, :cost => moulding.cost, :width => moulding.width } 
end 

这样,你应该有一个对象数组,包含你需要的那个成型的所有数据。在jQuery中,你就可以遍历这个数组,并抓住你需要的所有信息,如:

$.each(data.mouldings, function(index, moulding) { 
    alert("This moulding has an id of " + moulding.id + " and costs " + moulding.cost); 
}); 

我想,这使得很多更有意义比显式调用:

data.mouldings。 moulding_id_2。成本

如果你想找到确切moulding_id#2,那么你应该遍历数据集正如我上面显示,并执行这样的检查:

if (moulding.id == 2) {//do something}; 
+0

我想使用JSON订阅源中的所有数据在客户端上执行计算。使用`data.mouldings.moulding_id_2.cost`和`data.material_costs.mountboard.cost`这样的数据来获取数据,而不是通过数据做多重循环确实不容易? – freshest 2010-12-08 13:15:14

0

在时刻,线条是单身哈希列表。你希望它是一个单一的散列映射id到详细散列。