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

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

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

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

JavaScript

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

HTML

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

2回答

3789閲覧

JSの「scrollTop」が機能しないです。

beginner.tanaka

総合スコア23

Ruby on Rails

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

JavaScript

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

HTML

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2020/10/27 03:01

前提・実現したいこと

メッセージをやり取りする場所を作成しております。
最終的には、画面を読み込んだ際に、1番下にスクロールされる様にしたいです。
しかし、
うまくいかなかった為、試しに高さ1000pxの場所に移動させてみようと思い実行したのですが
これでもうまくいっておりません。

ご教授のほどよろしくお願いします。

現状

読み込んでも、スクロールされない。

該当のソースコード

rails

1 <div class="contents"> 2 <div id="contents"> 3 <% @messages.each do |message| %> 4 <div class="content_entire"> 5 <div class="content"> 6 <p><%= message.content %></p> 7 </div> 8 </div> 9 <% end %> 10 </div> 11 </div>

js

1function load (){ 2 let target = document.getElementById('contents'); 3 target.scrollTop = 1000; 4 console.log(target.scrollTop = 1000) //コンソール上では表示されます 5}window.onload = load;

試したこと

コンソール上では、問題なく[1000]と表示されている為、
数値は取得できていると思います。
記述ミスがありましたら、ご指摘のほどよろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

JSの「scrollTop」が機能しないです。

読み取り専用のプロパティですので、代入による位置指定はできません。

> MDN scrollTop
> The Window.screenTop read-only property returns the vertical distance,
in CSS pixels, from the top border of the user's browser viewport to the top side of the screen.
(引用ミスのため削除)

目的の要素まで移動したい場合、以下のメソッドがあります。

細かなオプションには未対応のブラウザもありますが、(主流といえそうなブラウザでは)とりあえずの移動ができるようです。

1番下にスクロールされる様にしたい

ブラウザ上でページの最下位置にある要素をターゲットに試しても良いと思います。

投稿2020/10/27 03:28

編集2020/10/27 06:39
AkitoshiManabe

総合スコア5434

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

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

beginner.tanaka

2020/10/27 05:07

回答していただき、ありがとうございます。 scrollIntoViewで実装したところ、うまく行きました。 1点質問なのですが、下記のURLを参考に実施したのですが、 「代入による位置指定ができない」という意味がよくわかりません。 let target = document.getElementById('contents'); で、targetを変数にし、この変数を使った位置指定ができないということでしょうか? https://techacademy.jp/magazine/32976 こちらのサイトでも、同じ様な記述をしております。 もし可能であれば、教えていただきたいです。
AkitoshiManabe

2020/10/27 06:02

> 代入による位置指定ができない 打ち消し線の通り、誤答部分です(リファレンスの 「scrollTop」を参照すべきでしたが、リンク先の通り「screenTop」の解説を引用していました。混乱させてしまい申し訳ありません。
beginner.tanaka

2020/10/27 06:27

かしこまりました!ありがとうございます。
guest

0

console.log(target.scrollTop = 1000)

代入式をコンソールしても右辺の値が拾えるだけで
target.scrollTopが変更されていることは確認できません
また基本的にscrollTopはbodyに対して処理してください

投稿2020/10/27 03:27

編集2020/10/27 03:44
yambejp

総合スコア116724

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

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

yambejp

2020/10/27 03:44 編集

document.querySelector('body').scrollTop = document.documentElement.offsetHeight; もしくはwindowへのscroll処理 window.scroll({ top: document.documentElement.offsetHeight, behavior: "smooth" });
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問