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

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

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

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

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

CSS

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

Q&A

0回答

987閲覧

position: fixed; した要素を、親要素スクロールバーの内側に置きたい

carryzuki

総合スコア4

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

HTML

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

CSS

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

0グッド

0クリップ

投稿2019/11/24 12:09

前提

bodyをスクロールさせず、内側の.scrollという要素をスクロールさせています。

###実現したいこと
下記ソースコードにおいて、.infomation(赤い要素)を、.contents(青い要素)と同じ左右位置(つまりスクロールバーが加味された幅の真ん中)に置きたいです。

発生している問題

赤い要素はfixedしてあるためにスクロールバーの位置が加味されず、青い要素より少し右に位置してしまうことが問題です。

該当のソースコード

実際のサンプルを作りました。
https://jsfiddle.net/4gyxa276/

白い点線があるように、赤い要素が右にズレてしまっているのがお分かりいただけるかと思います。

下記は上のサンプルのソースコードになります。

html

1<div class="scroll"> 2 <div class="outer"> 3 <div class="inner"> 4 <div class="contents">赤い要素を青い要素と同じ左右位置に置きたい</div> 5 </div> 6 </div> 7 <div class="infomation">infomation</div> 8</div>

CSS

1body { 2 overflow: hidden; 3 margin: 0; 4 padding: 0; 5} 6.scroll { 7 background: gray; 8 height: 100vh; 9 padding: 20px; 10 overflow-y: scroll; 11 overflow-x: hidden; 12} 13.inner { 14 background: black; 15 width: 100%; 16 height: 1000px; 17 display: flex; 18 justify-content: center; 19 align-items: start; 20} 21.contents { 22 background: blue; 23 width: 300px; 24 z-index: 999; 25 color: white; 26 position: relative; 27 padding: 10px; 28} 29.contents:before, 30.contents::after { 31 content: ''; 32 position: absolute; 33 height: 1000px; 34 width: 2px; 35 top: 0; 36} 37.contents::before { 38 border-left: 3px dotted white; 39 left: 0; 40} 41.contents::after { 42 border-right: 3px dotted white; 43 right: 0; 44} 45.infomation { 46 position: fixed; 47 background: red; 48 width: 300px; 49 bottom: 50px; 50 padding: 10px; 51 left: 0; 52 right: 0; 53 margin: 0 auto; 54}

試したこと

まず.scrollでなくbodyにスクロールバーをつければ問題は解決しました。
しかし前提があるので採用できませんでした。

次にposition:stickyを使えば問題は解決しました。
しかし非対応ブラウザがあるため採用しませんでした。

あとは.innerの内側に.infomationを置きましたが、これでは問題は解決できませんでした。

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

特筆すべきバージョンや環境はございません。

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

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

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

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

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

s8_chu

2019/11/24 14:26

HTML の構造は多少変更しても良いでしょうか?
carryzuki

2019/11/24 14:35

コメントありがとうございます。多少の変更はなんとかできると思います。また何かございましたら宜しくお願い致します。
s8_chu

2019/11/24 14:46

もうひとつ質問ですが、 JavaScript タグがあるということは、 position: sticky の polyfill を使用しても構わないということでしょうか? https://github.com/wilddeer/stickyfill
x_x

2019/11/25 07:34

対応すべきブラウザは IE11 でしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問