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

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

ただいまの
回答率

88.04%

画像付き投稿機能の実装

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 187

score 1

前提・実現したいこと

画像付きの投稿を実装したい
投稿内容を入力した後に投稿ボタンを押してもそこから画面が固まってしまいます
入力内容ももちろん保存されていません

発生している問題・エラーメッセージ

ターミナルを見ると以下の記述があります

No template found for PostsController#create, rendering head :no_content
Completed 204 No Content in 24058ms (ActiveRecord: 0.0ms | Allocations: 10511)

該当のソースコード

こちらがコントローラーです

class PostsController < ApplicationController
  def index
    @posts = Post.all
  end

  def new
    @post = Post.new
  end

  def create
    Post.create(post_params)
  end

  private
  def post_params
    params.require(:post).permit(:title, :image, :text)
  end
end


こちらがビューです
app/views/posts/new.html.erb

<div class="contents row">
  <div class="container">
    <h3>投稿する</h3>
    <%= form_with(model: @post, local: true) do |form| %>
      <%= form.text_field :title, placeholder: "タイトル" %>
      <%= form.file_field :image, id:"post-image" %>
      <%= form.text_area :text, placeholder: "投稿内容を記述してください", rows: "10" %>
      <%= form.submit "投稿" %>
    <% end %>
  </div>
</div>

試したこと

binding.pryをして情報を渡せているのか試したところ、以下の表記でpermittedがfalseになっている

[1] pry(#<PostsController>)> params
=> <ActionController::Parameters {"authenticity_token"=>"PG+A/QmI3GO7axuZa+q7PG978F6Xcmy5gRp5tTPILgrgwc66Eo0bzGaUdwC5+XFq9fp9WlEcRdncwOihp8hC9Q==", "post"=>{"title"=>"test", "image"=>#<ActionDispatch::Http::UploadedFile:0x00007ff1498efae8 @tempfile=#<Tempfile:/var/folders/vh/zl0b2_nx6gv6w0p7d1v_j2_r0000gn/T/RackMultipart20201205-85047-fseexi.jpg>, @original_filename="shutterstock_1005938026.jpg", @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"post[image]\"; filename=\"shutterstock_1005938026.jpg\"\r\nContent-Type: image/jpeg\r\n">, "text"=>"test"}, "commit"=>"投稿", "controller"=>"posts", "action"=>"create"} permitted: false>


ストロングパラメーターに関する問題でしょうか?

補足情報(FW/ツールのバージョンなど)

mac のバージョンは10.15.7
rails _6.0.0_にて実装しています

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • m.ts10806

    2020/12/05 05:56

    ビューのファイル名と設置場所を記載してください。
    ※でも、エラーの通りだろうなと思います

    キャンセル

  • comrade

    2020/12/05 08:14

    ファイル名は
    new.html.erbです
    設置場所は
    app/views/posts/new.html.erb
    です。
    保存するための必要情報が足りていないということでしょうか?

    キャンセル

回答 1

checkベストアンサー

0

ファイル名は
new.html.erbです
設置場所は
app/views/posts/new.html.erb

しかしRailsが欲しているテンプレートファイル名はnewではなくcreate ですよね。エラーの通り。
newからcreateが実行されているようですが、createメソッドに対応するviewが作られてない(または作っていても場所が違う)ことが原因です。

エラーメッセージをGoogle翻訳で訳すと下記の通り

PostsController#createのテンプレートが見つかりません、レンダリングヘッド:no_content

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/12/05 19:34

    新しく
    app/views/posts/create.html.erb
    設置することで解決しました。
    ありがとうございました!

    キャンセル

  • 2020/12/05 19:47

    要件次第ですがデータ更新部分を非同期にするなどして余計なviewを作らないようにするなど工夫された方が良いかと思います。

    キャンセル

  • 2020/12/06 19:48

    ありがとうございます!実践してみます。

    キャンセル

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

  • ただいまの回答率 88.04%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る