订单数组。数组的未定义方法`order'。将数组转换为哈希?

时间:2013-03-31 14:27:37

标签: ruby-on-rails arrays ruby-on-rails-3 hash

我有一个城市模型,并且在城市的展示活动中,我想要在城市中的特定位置附近呈现酒店。城市有很多地方;正在使用Geocoder near method搜索酒店。

要添加订单功能,我一直关注Ryan Bates screencasts #228,但这种方法似乎不适用于数组,给出错误undefined method `order' for #< Array:0x007f960d003430>

cities_controller.rb

helper_method :sort_column, :sort_direction
def show
  session[:search_radius] = 2 if session[:search_radius].blank?
  @city = City.find(params[:id])
  @locations = @city.locations
  @hotels = []
  @locations.each do |location|
    unless location.longitude.blank? || location.latitude.blank? 
      center_point = [location.latitude, location.longitude]
      box = Geocoder::Calculations.bounding_box(center_point, session[:search_radius])
      thotels = Hotel.near(center_point, session[:search_radius]).within_bounding_box(box)
    else
      thotels = Hotel.near(center_point, session[:search_radius])
    end
    @hotels += thotels if thotels
    @hotels = @hotels.uniq
  end
  @hotels = @hotels.order(sort_column + " " + sort_direction).paginate(:page => params[:page], :per_page => 5)
  @json = @locations.to_gmaps4rails

  respond_with @json, :location => city_url
end


private

  def sort_column
    Hotel.column_names.include?(params[:sort]) ? params[:sort] : "name"
  end

  def sort_direction
    %w[asc desc].include?(params[:direction]) ? params[:direction] : "asc"
  end

我的问题是:我应该专注于将数组转换为哈希值,还是应该首先创建酒店哈希值,还是找到完全不同的方法来执行排序?

1 个答案:

答案 0 :(得分:10)

order是一种用于在数据库级别进行排序的方法。由于@hotels是一个数组,因此您将无法使用order进行排序。尝试以下操作(未经测试,如果尚未包含数组分页,则可能需要包含数组分页)

@hotels = @hotels.sort_by(&:"#{sort_column}")
@hotels = @hotels.reverse if sort_direction == 'DESC'
@hotels = @hotels.paginate(:page => params[:page], :per_page => 5)