🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Action Cable

Action Cableは、WebSocketをRailsに組み込む機能。Rails4でオプションとして存在していたWebSocketをRails5で標準機能したものです。Railsアプリケーションと同様のスタイルで、Rubyを用いたリアルタイム機能を記述できます。

Ruby

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

Ruby on Rails

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

Q&A

解決済

1回答

1056閲覧

rails6で作成中のチャットアプリがリアルタイム更新されない

hiroro0820

総合スコア13

Action Cable

Action Cableは、WebSocketをRailsに組み込む機能。Rails4でオプションとして存在していたWebSocketをRails5で標準機能したものです。Railsアプリケーションと同様のスタイルで、Rubyを用いたリアルタイム機能を記述できます。

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2019/11/25 02:58

編集2019/11/25 03:39

リアルタイムでメッセージを表示させたい

『【Rails6.0】ActionCableとDeviseの欲張りセットでリアルタイムチャット作成(改正版)』
https://qiita.com/eRy-sk/items/4c4e983e34a44c5ace27

この記事を参考にrailsでコミュニティー型のsnsをつくっています。
そして、これにコミュニティ作成機能を追加しました。

メッセージがフロントに表示されない

サーバーにデータは保存されているようなのですが、
送信されたメッセージが表示されなくて困っています。

コミュニティ作成機能を追加して、
作成したコミュニティ内でメッセージ送信後の挙動を確認してみたところ
メッセージがリアルタイムで更新されなくなってしまいました。

コミュニティー作成を行う前までは、ちゃんと動いていました、、

該当のソースコード

app/channels/community_channel.rb

class CommunityChannel < ApplicationCable::Channel def subscribed stream_from "community_channel_#{params['community']}" end def unsubscribed # Any cleanup needed when channel is unsubscribed end def speak(data) Message.create! content: data['message'], user_id: current_user.id, community_id: params['community'] end end

app/javascript/channels/community_channel.js

import consumer from './consumer' $(function() { const chatChannel = consumer.subscriptions.create({ channel: 'CommunityChannel', community: $('#messages').data('community_id') }, { connected() { // Called when the subscription is ready for use on the server }, disconnected() { // Called when the subscription has been terminated by the server }, received: function(data) { return $('#messages').append(data['message']); }, speak: function(message) { return this.perform('speak', { message: message }); } }); // data-behaviorがcommunity_speakerである場所でkeypressすると... $(document).on('keypress', '[data-behavior~=community_speaker]', function(event) { if (event.keyCode === 13) { chatChannel.speak(event.target.value); event.target.value = ''; return event.preventDefault(); } }); });

app/jobs/message_broadcast_job.rb

class MessageBroadcastJob < ApplicationJob queue_as :default def perform(message) # Do something later ActionCable.server.broadcast "commnity_channel_#{message.community_id}", message: render_message(message) end private def render_message(message) ApplicationController.renderer.render partial: 'messages/message', locals: { message: message } end end

app/views/communities/show.html.erb

<div id='messages' data-community_id="<%= @community.id %>"> <%= render @messages %> </div> <%= label_tag :content, @community.name %> <%= text_field_tag :content, nil, data: { behavior: 'community_speaker' } %>

app/views/messages/_message.html.erb

<div class='message'> <p><%= "#{message.user.email}: #{message.content}" %></p> </div>

やってみたこと。

turbolinksを削除した。

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

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

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

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

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

guest

回答1

0

自己解決

スペルミスでした。
以下のように変更しました。

app/jobs/message_broadcast_job.rb

1class MessageBroadcastJob < ApplicationJob 2 queue_as :default 3 4 def perform(message) 5 # Do something later 6 ActionCable.server.broadcast "community_channel_#{message.community_id}", message: render_message(message) 7 end 8 9 private 10 11 def render_message(message) 12 ApplicationController.renderer.render partial: 'messages/message', locals: { message: message } 13 end 14end

投稿2019/11/26 06:03

hiroro0820

総合スコア13

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問