我有以下方法检索2个日期之间的所有约会:
def self.search_app(start_date, end_date)
if start_date
start_date = Date.new(start_date['(1i)'].to_i, start_date['(2i)'].to_i, start_date['(3i)'].to_i)
end_date = Date.new(end_date['(1i)'].to_i, end_date['(2i)'].to_i, end_date['(3i)'].to_i)
find(:all, :conditions => {:date_of_appointment => (start_date)..(end_date) })
else
find(:all)
end
end
并在视图中:
<div id="search">
<% form_tag doctor_appointments_path(@person), :method => "get" do %>
<span> From </span>
<%= date_select :start_date, :start_date %>
<span> Until </span>
<%= date_select :end_date, :end_date %>
<%= submit_tag "Search", :name => nil %>
<% end %>
</div>
控制器代码:
def index
@appointments = person.appointments.search_app(params[:start_date], params[:end_date])
end
方法在第一次调用时效果很好,但是如果我再次尝试搜索,我会得到一个参数错误:
Invalid date
{"start_date"=>{"start_date(1i)"=>"2010",
"start_date(2i)"=>"8",
"start_date(3i)"=>"5"},
"doctor_id"=>"1",
"end_date"=>{"end_date(3i)"=>"17",
"end_date(1i)"=>"2010",
"end_date(2i)"=>"8"}}
不知怎的,它用Date.new方法传递了医生ID?
任何想法如何解决这个问题?
谢谢
答案 0 :(得分:1)
date_select :start_date, :start_date
告诉我们有一个@start_date
对象可供使用,.start_date
属性将由日期选择提供。
您可能最好使用select_date
来传递日期,并且您需要一个前缀来区分开始日期和结束日期。例如:
select_date Date.current, :prefix => 'start'