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

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

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

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

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

0回答

551閲覧

jsファイルに他のテーブルデータを反映させる

yummy-

総合スコア5

Ruby on Rails 5

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

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2020/02/29 22:54

前提・実現したいこと

メッセージ送信機能を非同期化しました。メッセージ本体に削除機能をつけたくmessage.jsに${group.id}を反映させたいです。(groupにmessageをネストさせてます)

該当のソースコード

js

1$(function(){ 2 function buildHTML(message){ 3 var html = 4 `<%= link_to "/groups/${group.id }/messages/${message.id}", method: :delete do%> 5 <div class="card"> 6 <div class="card-body"> 7 <h3 class="card-content">${message.content}</h3> 8 <h6 class="card-user">${message.user_name}</h6> 9 </div> 10 </div> 11 <h1>????</h1>` 12 return html; 13 } 14 $('#new_message').on('submit', function(e){ 15 e.preventDefault(); 16 var formData = new FormData(this); 17 var url = $(this).attr('action') 18 $.ajax({ 19 url: url, 20 type: "POST", 21 data: formData, 22 dataType: 'json', 23 processData: false, 24 contentType: false 25 }) 26 .done(function(data){ 27 var html = buildHTML(data); 28 $('.row.c').append(html); 29 $('.row.c').animate({ scrollTop: $('.row.c')[0].scrollHeight}); 30 $('form')[0].reset(); 31 $('.btn.btn-success').prop( 'disabled', false ); 32 }) 33 .fail(function() { 34 alert("メッセージ送信に失敗しました"); 35 }); 36}) 37});

controller

1class MessagesController < ApplicationController 2 before_action :set_group 3 before_action :move_to_index, except: :index 4 5 def index 6 @message = Message.new 7 @messages = @group.messages.includes(:user) 8 end 9 10 def create 11 @message = @group.messages.new(message_params) 12 if @message.save 13 respond_to do |format| 14 format.json 15 end 16 else 17 redirect_to group_messages_path(@group) 18 end 19 end 20 21 def destroy 22 message = Message.find(params[:id]) 23 message.destroy 24 redirect_to group_messages_path(@group) 25 end 26 27 private 28 29 def message_params 30 params.require(:message).permit(:content).merge(user_id: current_user.id) 31 end 32 33 def set_group 34 @group = Group.find(params[:group_id]) 35 end 36 37 def move_to_index 38 redirect_to action: :index unless user_signed_in? 39 end 40end 41

jbuilder

1json.id @message.id 2json.user_name @message.user.name 3json.created_at @message.created_at.strftime("%Y年%m月%d日 %H時%M分") 4json.content @message.content 5json.image @message.image

試したこと

set_groupにrespond_toやrenderを試し、jbuilderに@group.idを記述しましたが反映されないです。
ご教授よろしくお願いします。

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

Rails 5.0.7.2
ruby 2.5.1p57 (2018-03-29 revision 63029) [x86_64-darwin18]

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問