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

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

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

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

Ruby on Rails

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

Q&A

解決済

1回答

2390閲覧

Ruby 非同期「登録&解除ボタン」No templateでエラーがでる

kkbeams

総合スコア17

Ruby

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

Ruby on Rails

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

0グッド

0クリップ

投稿2020/09/06 08:25

rails で非同期で登録部分を作っています。

ボタン状態:登録
↓ 登録ボタン押す(createされるがレンダリングされない) ※ここが問題点
リロード

ボタン状態:解除
↓ 解除ボタン押す(destroyされるがレンダリングされない) ※ここが問題点
リロード

ボタン状態:登録

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

createした時

No template found for UserLessonRelationsController#create, rendering head :no_content

destroyした時

No template found for UserLessonRelationsController#destroy, rendering head :no_content

routes.rb

Ruby

1Rails.application.routes.draw do 2 resources :lessons, only: [:index] do 3 resources :user_lesson_relations, only: [:create, :destroy] 4 end 5end

model

lesson.rb

Ruby

1class Lesson < ApplicationRecord 2 has_many :user_lesson_relations, dependent: :destroy 3 has_many :users, through: :user_lesson_relations 4end

user_lesson_relation.rb

Ruby

1class UserLessonRelation < ApplicationRecord 2 belongs_to :user 3 belongs_to :lesson 4 5 validates :user_id, presence: true 6 validates :lesson_id, presence: true 7end

controller

lessons_controller.rb

Ruby

1class LessonsController < ApplicationController 2 3 def index 4 @lessons = Lesson.all 5 end 6 7end

user_lessons_relations_controller.rb

Ruby

1class UserLessonRelationsController < ApplicationController 2 before_action :set_variables 3 4 def create 5 @user_lesson_relation = UserLessonRelation.create(lesson_id: @lesson.id, user_id: current_user.id) 6 end 7 8 def destroy 9 @user_lesson_relation = UserLessonRelation.find_by(lesson_id: @lesson.id) 10 if @user_lesson_relation.user_id != current_user.id 11 return redirect_to root_path 12 else 13 @user_lesson_relation.destroy 14 end 15 end 16 17 private 18 19 def set_variables 20 @lesson = Lesson.find(params[:lesson_id]) 21 @id_name = "#lesson_register_buttons_#{@lesson.id}" 22 end 23 24end

###View
app/views/lessons/index.html.erb

<div class="lessons-wrapper"> <% @lessons.each do |lesson| %> <div class="lesson-btn-wrapper" id="lesson_register_buttons_<%= lesson.id %>"> <%= render partial: 'lessons/user_lesson_relations/lesson_registration', locals: { lesson: lesson} %> </div> <% end %> </div>

app/views/lessons/user_lesson_relations/_lesson_registration.html.erb

<% if UserLessonRelation.exists?(user_id: current_user.id, lesson_id: lesson.id) %> <%= button_to "解除", lesson_user_lesson_relation_path(lesson.id, lesson.id), method: :delete, class:"buy-btn remove-lesson-btn" %> <% else %> <%= button_to "登録", lesson_user_lesson_relations_path(lesson.id), method: :post, class:"buy-btn" %> <% end %>

app/views/lessons/user_lesson_relations/create.js.erb
app/views/lessons/user_lesson_relations/destroy.js.erb

$('<%= @id_name %>').html("<%= j(render partial: 'user_lesson_relations/lesson_registration', locals: {lesson: @lesson}) %>");

試したこと

ルーティングがネスト構造になっているため、viewファイルの位置がおかしいのかと思い、フォルダー作ったり、ファイルを移動させたりしたのですが、解決できませんでした。。。

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

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

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

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

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

guest

回答1

0

ベストアンサー

action create,delete が終わった時、無指定だと create.html.*、delete.html.*を使おうとします。
lessonsのindexに戻りたいのでしょうか?
でしたら 
@lessons = Lesson.all render controller: :lessons, adtion: :index
としてください。

ごめん、非同期か
ですと 上のではなく
app/views/user_lesson_relations/create.js.erb
app/views/user_lesson_relations/destroy.js.erb
に画面書き直しを書いてください

ルーティングがネスト構造になっているかどうかには関係なく、
contollerの名前に基づく dirにviewファイルを置きます

投稿2020/09/06 09:44

編集2020/09/06 09:50
winterboum

総合スコア23329

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

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

kkbeams

2020/09/08 23:03

app/views/user_lesson_relations/create.js.erb app/views/user_lesson_relations/destroy.js.erb app/views/user_lesson_relations/_lesson_registration.html.erb という形にして、partialもそれぞれ partial: 'user_lesson_relations/lesson_registration' としたのですが、同じエラーになります。。
winterboum

2020/09/08 23:15

同じエラー とは 「同じような」ですか「エラーメッセージが全く一字も変わらず同じ」ですか?
kkbeams

2020/09/08 23:31

createすると ActionController::UnknownFormat (UserLessonRelationsController#create is missing a template for this request format and variant. こうなってしまいます。。
winterboum

2020/09/08 23:55

create.jsが見つからないのか、partialが見つからないのか、partialの内容に問題があってあたかもtemplateが見つからないかのごとくなのか切り分けましょう。 1. partial の中を空にしてやってみる 2. create の中身を空にしてやってみる これでやるとどう変わりますか?
kkbeams

2020/09/09 00:07

createの中身を消しても同じエラーが出て、createが呼び出されてないんだなと思って、partial内にremote: true を加えたら非同期で反応しました! winterboumさんのおかげで解決できました!他にも知見が得られたので非常にありがたいです!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問