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

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

詳細はこちら
Ruby on Rails 5

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

Ruby

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

Ruby on Rails

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

JavaScript

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

Q&A

解決済

1回答

2672閲覧

チャット画面で、常にスクロールバーを最下部に表示させたい。

punchan36

総合スコア105

Ruby on Rails 5

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

Ruby

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

Ruby on Rails

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

JavaScript

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

0グッド

0クリップ

投稿2020/12/22 08:51

前提・実現したいこと

チャット画面をスクロールで表示しています。
メッセージが多くなり画面の幅を超えると、スクロールバーは上(一番古いメッセージ位置)に表示されるようになります。

LINE等のように表示位置を下(一番新しいメッセージ位置)に固定したくJavaScriptで実装してみたのですが、何も動いてくれません。コードは過去の質問を参考に実装致しました。
エラーメッセージは表示されず、単純にJavaScriptを記述する前と同様、スクロールバーが上に表示されたままになってしまっております。

お力をお貸し頂けると有難いです。

該当のソースコード

room_show.html.erb

rails

1 <div class="message-details messageDetails" id="scroll-inner"> 2 <% if @messages.present? %> 3 <% @messages.includes(:user).each do |m| %> <!-- 以下のメッセージ情報を繰り返し表示。--> 4 <div class="message-detail"> 5 <div class="message-detail-left"> 6 <%= link_to user_path(@user) do %> 7 <img src="<%= "/user_images/#{m.user.image_name}" %>"> 8 <% end %> 9 </div> 10 <div class="message-center-message"><%= m.content %></div> 11 <div class="message-right"> 12 <div class="message-date" style="color: #C0C0C0;"><%= m.updated_at.strftime("%Y/%m/%d") %></div> 13 <div class="message-time" style="color: #C0C0C0;"><%= m.updated_at.strftime("%H:%M") %></div> 14 </div> 15 </div> 16 <% end %> 17 <% end %> 18 </div>

rooms.scss

css

1.message-details { 2 height: 57vh; 3 overflow-y: scroll; 4}

scroll.js

javascript

1function scrollToEnd() { 2 const messageDetails = document.getElementById('scroll-inner'); 3 messageDetails.scrollTop = messageDetails.scrollHeight; 4}

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

ruby 2.6.4p104
RubyGems 3.0.3
Rails 5.2.3

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

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

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

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

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

guest

回答1

0

自己解決

scroll.jsファイル内を以下の様に書き換える事で解決しました!
関数の呼び出しなど、記述が不十分でした。

scroll.js

JavaScript

1document.addEventListener("turbolinks:load", () => { 2 function scrollToEnd() { 3 const messageDetails = document.getElementById('scroll-inner'); 4 messageDetails.scrollTop = messageDetails.scrollHeight; 5 } 6 scrollToEnd() 7})

投稿2020/12/24 09:41

punchan36

総合スコア105

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問