【发布时间】:2012-10-08 05:52:34
【问题描述】:
我只与 Ruby 合作了很短的时间,今天我在处理日历以提出请求时碰壁了。我花时间在 stackoverflow、ruby 指南等上搜索不同的未定义方法错误文档,以及查看 strftime。我找到了一个使用 try 部分解决了我的问题的解决方案,但现在它实际上并没有通过 strftime 来显示在请求上,即使 rails 服务器在帖子中接收它。我可以很好地访问我的日历,然后点击新的请求按钮,填写表格,但是当我发布该表格时,浏览器会给我这个:
undefined method `strftime' for nil:NilClass
Extracted source (around line #3):
1: <h1><%= @vacationrequest.request_name %></h1>
2:
3: <p class="info">Requested For <%= @vacationrequest.request_date.strftime("%B %e, %Y") %></p>
4:
5: <%= simple_format @vacationrequest.message %>
6:
我在 Rails 服务器上收到此错误:
Started GET "/vacationrequests/1" for 127.0.0.1 at 2012-10-17 15:18:14 -0400
Processing by VacationrequestsController#show as HTML
Parameters: {"id"=>"1"}
←[1m←[35mVacationrequest Load (0.0ms)←[0m SELECT "vacationrequests".* FROM "v
acationrequests" WHERE "vacationrequests"."id" = ? LIMIT 1 [["id", "1"]]
Rendered vacationrequests/show.html.erb within layouts/application (15.6ms)
Completed 500 Internal Server Error in 31ms
ActionView::Template::Error (undefined method strftime' for nil:NilClass):
1: <h1><%= @vacationrequest.request_date %></h1>
2:
3: <p class="info">Requested For <%= @vacationrequest.request_date.strftime(
"%B %e, %Y") %></p>
4:
5: <%= simple_format @vacationrequest.message %>
6:
app/views/vacationrequests/show.html.erb:3:inapp_views_vacationrequests_sho
w_html_erb_217743956_18446544'
这是我的表演视图:
<h1><%= @vacationrequest.request_name %></h1>
<p class="info">Requested For <%= @vacationrequest.request_date.strftime("%B %e, %Y") %></p>
<%= simple_format @vacationrequest.message %>
<p>
<%= link_to "Edit Request", edit_vacationrequest_path(@vacationrequest) %> |
<%= link_to "Back to Requests", vacationrequests_path %>
</p>
这是用户将请求信息放入的_form:
<%= form_for @vacationrequest do |f| %>
<% if @vacationrequest.errors.any? %>
<div id="error_explanation">
<h2><%= pluralize(@vacationrequest.errors.count, "error") %> prohibited this request from being saved: if this continue to happens please email the error to alex@allsafeindustries.com</h2>
<ul>
<% @vacationrequest.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<% end %>
<div class="field">
<%= f.label :request_name %><br />
<%= f.text_field :request_name %>
</div>
<div class="field">
<%= f.label :request_date %><br />
<%= f.text_field :request_date %>
</div>
<div class="field">
<%= f.label :message %><br />
<%= f.text_area :message %>
</div>
<div class="actions">
<%= f.submit %>
</div>
<% end %>
最后是我的控制器中的显示和索引方法:
def index
@vacationrequests = Vacationrequest.all
@vacationrequests_by_date = @vacationrequests.group_by(&:request_date)
@date = params[:date] ? Date.parse(params[:date]) : Date.today
end
def show
@vacationrequest = Vacationrequest.find(params[:id])
end
谁能告诉我什么是不合适的或者为什么这是零?谢谢。
作为对答案的回应,我现在从服务器得到了什么:
Started POST "/vacationrequests" for 127.0.0.1 at 2012-10-17 20:18:00 -0400
Processing by VacationrequestsController#create as HTML
Parameters: {"utf8"=>"√", "authenticity_token"=>"E1+xXP0pAIQpwMZruswxIZIrTZB3b
c3NlW3iRv9OLqU=", "vacationrequest"=>{"request_name"=>"One more time", "request_
date"=>"10/31/2012", "message"=>"Lucky number 7?"}, "commit"=>"Create Vacationre
quest"}
←[1m←[35m (0.0ms)←[0m begin transaction
←[1m←[36mSQL (15.6ms)←[0m ←[1mINSERT INTO "vacationrequests" ("created_at", "
message", "request_date", "request_name", "updated_at") VALUES (?, ?, ?, ?, ?)←[
0m [["created_at", Thu, 18 Oct 2012 00:18:00 UTC +00:00], ["message", "Lucky nu
mber 7?"], ["request_date", nil], ["request_name", "One more time"], ["updated_a
t", Thu, 18 Oct 2012 00:18:00 UTC +00:00]]
←[1m←[35m (109.2ms)←[0m commit transaction
Redirected to http://localhost:3000/vacationrequests/7
Completed 302 Found in 125ms (ActiveRecord: 124.8ms)
Started GET "/vacationrequests/7" for 127.0.0.1 at 2012-10-17 20:18:01 -0400
Processing by VacationrequestsController#show as HTML
Parameters: {"id"=>"7"}
←[1m←[36mVacationrequest Load (0.0ms)←[0m ←[1mSELECT "vacationrequests".* FRO
M "vacationrequests" WHERE "vacationrequests"."id" = ? LIMIT 1←[0m [["id", "7"]
]
Rendered vacationrequests/show.html.erb within layouts/application (15.6ms)
Completed 500 Internal Server Error in 16ms
ActionView::Template::Error (undefined method `strftime' for nil:NilClass):
1: <h1><%= @vacationrequest.request_name %></h1>
2: <%= debug @vacationrequest %>
3: <p class="info">Requested For <%= @vacationrequest.request_date.strftime(
"%B %e, %Y") %></p>
4:
5: <%= simple_format @vacationrequest.message %>
6:
app/views/vacationrequests/show.html.erb:3:in `_app_views_vacationrequests_sho
w_html_erb___377763931_36688344'
我还使用了视图调试并检查了我的方案,所有属性似乎都正确排列。
至于 cmets 中的请求,这里是我的 Vacationrequest 模型:
class Vacationrequest < ActiveRecord::Base
attr_accessible :message, :request_name, :request_date
end
再次感谢您的帮助。
这是架构:
ActiveRecord::Schema.define(:version => 20121016194123) do
create_table "vacationrequests", :force => true do |t|
t.string "request_name"
t.date "request_date"
t.text "message"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
end
以及创建控制器动作代码:
def create
@vacationrequest = Vacationrequest.new(params[:vacationrequest])
if @vacationrequest.save
redirect_to @vacationrequest, notice: "Created Request!"
else
render :new
end
end
当我看到这个时,我的架构是复数而我的控制器是单数是问题的一部分吗?再次感谢。
【问题讨论】:
-
问题是
@vacationrequest.request_date出于某种原因为零。你能发布Vacationrequest模型的代码吗? -
我在服务器错误输出中添加,并使用调试属性信息检查了我的架构。该模型也已添加。
-
果然问题不是在显示记录时出现,而是在保存时出现。您可以发布您的数据库架构和
create控制器操作代码吗? -
我在之前的编辑下添加了它。我注意到我的模式是复数形式,而我的控制器主要使用单数语法。我不确定这是否会有所作为。再次感谢您,我真的很感激。
-
一件事:如果您想确保在创建新记录时输入日期,您可能应该在模型中添加一个验证器。尝试在您的
Vacationrequest模型中添加一行:validates :request_date, :presence => true,然后尝试创建新的休假请求。你应该得到一个错误。
标签: ruby-on-rails ruby ruby-on-rails-3 methods null