如何从Rails中的date_select或select_date获取日期?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何从Rails中的date_select或select_date获取日期?相关的知识,希望对你有一定的参考价值。
使用select_date
给了我一个params[:my_date]
与year
,month
和day
属性。如何轻松获取Date对象?我希望像params[:my_date].to_date
这样的东西。
我很高兴也使用date_select
。
使用date_select分别为日,月和年提供3个单独的键/值对。因此,您可以将它们作为参数传递给Date.new
以创建新的Date对象。
例子date_select为Event
模型返回了params:
"event"=>
{"name"=>"Birthday",
"date(1i)"=>"2012",
"date(2i)"=>"11",
"date(3i)"=>"28"},
然后创建新的Date
对象:
event = params[:event]
date = Date.new event["date(1i)"].to_i, event["date(2i)"].to_i, event["date(3i)"].to_i
您可以决定将此逻辑包装在一个方法中:
def flatten_date_array hash
%w(1 2 3).map { |e| hash["date(#{e}i)"].to_i }
end
然后将其称为date = Date.new *flatten_date_array params[:event]
。但这不是真正属于控制器的逻辑,因此您可能决定将其移动到其他位置。您甚至可以将其扩展到Date
类,并将其称为date = Date.new_from_hash params[:event]
。
这是另一个:
# view
<%= date_select('event', 'date') %>
# controller
date = Date.civil(*params[:event].sort.map(&:last).map(&:to_i))
在http://kevinlochner.com/use-rails-dateselect-without-an-activerecord找到
这是另一个
Date.civil(params[:event]["date(1i)"].to_i,params[:event]["date(2i)"].to_i,params[:event]["date(3i)"].to_i)
这是另一个rails 5:
module Convert
extend ActiveSupport::Concern
included do
before_action :convert_date
end
protected
def convert_date
self.params = ActionController::Parameters.new(build_date(params.to_unsafe_h))
end
def build_date(params)
return params.map{|e| build_date(e)} if params.is_a? Array
return params unless params.is_a? Hash
params.reduce({}) do |hash, (key, value)|
if result = (/(.*)(di)z/).match(key)
params_name = result[1]
date_params = (1..3).map do |index|
params.delete("#{params_name}(#{index}i)").to_i
end
hash[params_name] = Date.civil(*date_params)
else
hash[key] = build_date(value)
end
hash
end
end
end
您需要将它包含在您的控制器或application_controller.rb中:
class ApplicationController < ActionController::Base
include Convert
end
使用date_select示例@ joofsh的答案,这里是我使用的“一个班轮”,假设日期字段名为start_date
:
ev_params = params[:event]
date = Time.zone.local(*ev_params.select {|k,v| k.to_s.index('start_date(') == 0 }.sort.map {|p| p[1].to_i})
我使用以下方法,它具有以下好处:
- 它不必通过
xxx(1i)
明确命名参数键xxx(3i)
(因此可以修改为仅通过将Date
更改为DateTime
来捕获小时和分钟);和 - 它从一组
params
中提取日期,即使这些参数填充了许多其他键值对。
params
是{ xxx(1i): '2017', xxx(2i): 12, xxx(3i): 31, ... }
格式的哈希值; date_key
是目标日期参数的常见子串xxx
。
def date_from_params(params, date_key)
date_keys = params.keys.select { |k| k.to_s.match?(date_key.to_s) }.sort
date_array = params.values_at(*date_keys).map(&:to_i)
Date.civil(*date_array)
end
我选择将它作为ApplicationRecord
的类方法,而不是作为ApplicationController
的实例辅助方法。我的理由是,在ActiveRecord实例化器(即Model.new
)中存在类似的逻辑来解析从Rails表单传入的日期。
或者干脆做到这一点:
your_date_var = Time.parse(params[:my_date])
以上是关于如何从Rails中的date_select或select_date获取日期?的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Rails 中链接原始 SQL 查询或如何从 Rails 中的原始 SQL 查询返回 ActiveRecord_Relation?