質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1310閲覧

First argument in form cannot contain nil or be empty  なるエラーがでました(;~;)何卒・・・

TOKUSABU

総合スコア87

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2017/12/03 14:27

First argument in form cannot contain nil or be empty
なるエラーがでました。

原因は
app/views/tasks_/form_html_erbの

<%= form_for(@task) do |f| %> <% if @task.errors.any? %> <div id="error_explanation"> <h2><%= pluralize(@task.errors.count, "error") %> prohibited this task from being saved:</h2> <ul>

<%= form_for(@task) do |f| %>

が原因との事。
ググって原因を確認したところ
https://teratail.com/questions/16823
https://teratail.com/questions/63651
などありなんとなくわかりそうですが・・・・・
やはりわかりませんでした
コントローラーを修正する必要がありそうなのがぐぐりから感じるのですが・・・・
わからず・・・

。。。。。。

お知恵を拝借する事は可能でしょうか・・・(><)

ちなみにコントローラーは

class TasksController < ApplicationController before_action :authenticate_user! before_action :set_task, only: [:show, :edit, :update, :destroy] # GET /tasks # GET /tasks.json def index @tasks = Task.where(charge_id: current_user.id) end # GET /tasks/1 # GET /tasks/1.json def show end # GET /tasks/new def new @tasks = Task.where(charge_id: current_user.id) end # GET /tasks/1/edit def edit end # POST /tasks # POST /tasks.json def create @task = current_user.tasks.build(task_params) @task.charge_id = current_user.id respond_to do |format| if @task.save format.html { redirect_to @task, notice: 'Task was successfully created.' } format.json { render :show, status: :created, location: @task } else format.html { render :new } format.json { render json: @task.errors, status: :unprocessable_entity } end end end # PATCH/PUT /tasks/1 # PATCH/PUT /tasks/1.json def update respond_to do |format| if @task.update(task_params) format.html { redirect_to @task, notice: 'Task was successfully updated.' } format.json { render :show, status: :ok, location: @task } else format.html { render :edit } format.json { render json: @task.errors, status: :unprocessable_entity } end end end # DELETE /tasks/1 # DELETE /tasks/1.json def destroy @task.destroy respond_to do |format| format.html { redirect_to tasks_url, notice: 'Task was successfully destroyed.' } format.json { head :no_content } end end private # Use callbacks to share common setup or constraints between actions. def set_task @task = Task.find(params[:id]) end # Never trust parameters from the scary internet, only allow the white list through. def task_params params.require(:task).permit(:user_id, :title, :content, :deadline, :charge_id, :status) end end

となります。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

/tasks/new にアクセスしたらそのエラーが出たんですね?
(というようなことまでお書きになると解決が早いと思います)

new アクションのメソッドを見ると

rb

1 def new 2 @tasks = Task.where(charge_id: current_user.id) 3 end

となっていて,インスタンス変数 @tasksTask を絞り込んだものが入りますね。
インスタンス変数はビューのテンプレートで参照できます。

ところが,問題のフォームのテンプレートでは,

rb

1form_for(@task)

となっていて,@task(単数形)を使っています。こういうインスタンス変数は初期化していないので,値は nil です。
これがエラーの原因ですね。

では

rb

1form_for(@tasks)

と複数形にしてやればよいかというと,ダメです。

new メソッドの中身をよく見ると index メソッドの中身と同じですね。

何かを参考にして書かれたのだと思いますが,おそらく new を書くときに間違って index のほうをご覧になっていたのでしょう。

投稿2017/12/03 14:47

scivola

総合スコア2108

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TOKUSABU

2017/12/04 12:50

早急のご返信大変ありがとうございます! なるほど、記載を参考に試してみます 大変ありがとうございます!
TOKUSABU

2017/12/04 13:21

ご指摘大変ありがとうございました。 おっしゃられるとおりで、修正しましたら治りました!!! まだまだ初心者で、早くscivolaさんのようにコードを見て 直せるようになりたい・・・と思いました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問