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

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

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

HTTPS(Hypertext Transfer Protocol Secure)はHypertext Transfer プロトコルとSSL/TLS プロトコルを組み合わせたものです。WebサーバとWebブラウザの間の通信を暗号化させて、通信経路上での盗聴や第三者によるなりすましを防止します。

Ruby on Rails

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

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

HTML

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

Q&A

1回答

859閲覧

コメント機能非同期通信にて、ユーザー画像を表示させたいがリンク切れとなってしまう。

hana_123

総合スコア3

HTTPS

HTTPS(Hypertext Transfer Protocol Secure)はHypertext Transfer プロトコルとSSL/TLS プロトコルを組み合わせたものです。WebサーバとWebブラウザの間の通信を暗号化させて、通信経路上での盗聴や第三者によるなりすましを防止します。

Ruby on Rails

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

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

HTML

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

0グッド

0クリップ

投稿2020/11/13 09:11

前提・実現したいこと

コメント機能の実装をしています。
コメント自体の非同期通信の設定は完了しているのですが、
コメントをした際にコメントをしたユーザーのavatar画像を同時に表示させたいのですが、
画像がリンク切れとなってしまいます。

画像のようになっています。

https://gyazo.com/78b1cf4c16f1943b34261b63324f6f2f

ActiveRecordを用いてuser.avatarを登録しています。
画像をurl化しなければいけないかと思うのですが方法がわかりません・・・。

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

console

1 2%7Bundefined%7D:1 Failed to load resource: the server responded with a status of 404 (Not Found) 3

該当のソースコード

html

1 2 3 <div class="comments-all"> 4 <ul id="comments"> 5 <% if @comments.present? %> 6 <% @comments.reverse_each do |comment| %> 7 <div class='comment-context'> 8 <li> 9 <% if current_user.avatar.attached? %> 10 <%= image_tag(@post.user.avatar, class:"avatar-post") %> 11 <% end %> 12 <%= link_to comment.user.name, user_path(comment.user.id) %> : <%= comment.text %></li> 13 </div> 14 <% end %> 15 <% else %> 16 <div class="comment-do"> 17 NO COMMENT YET 18 </div> 19 <% end %> 20 </ul> 21 </div>

channel

1consumer.subscriptions.create("CommentChannel", { 2 connected() { 3 // Called when the subscription is ready for use on the server 4 }, 5 6 disconnected() { 7 // Called when the subscription has been terminated by the server 8 }, 9 10 received(data) { 11 const html = ` 12 <div class='comment-context'> 13 <li> 14 <img src={${data.user.avatar}} class="avatar-post" ></img> 15 <a href="user_path${data.user.id}">${data.user.name}</a>: ${data.content.text}</li> 16 </div>` 17 18 const comments = document.getElementById('comments'); 19 const newComment = document.getElementById('comment_text'); 20 comments.insertAdjacentHTML('afterbegin', html); 21 newComment.value=''; 22 } 23}); 24

試したこと

url_forを使用したのですがリンク切れは治りませんでした。

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

'rails', '~> 6.0.0'
'mysql2', '>= 0.5.3'
channelを用いての実装です。

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

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

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

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

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

guest

回答1

0

せっかくRailsを使っているなら標準機能のremote: trueを利用して非同期通信を行えば簡単に実装できます。
サンプルコード(Railsガイド)のreceive部分がjs.erbファイルなのでimage_urlも使いやすいです。

app/views/users/create.js.erbビューファイルを作成します。実際のJavaScriptはこのビューで生成され、クライアントに送信されてそこで実行されます。

$("<%= escape_javascript(render @user) %>").appendTo("#users");

投稿2020/11/13 10:01

no1knows

総合スコア3365

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

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

hana_123

2020/11/13 11:17

channel ActionCableを使用しての実装は難しいでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問