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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

HTML

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

CSS

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

Q&A

解決済

1回答

536閲覧

CSSのみでサイドバーを追従させたいのですが

panisyo

総合スコア9

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

HTML

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

CSS

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

0グッド

0クリップ

投稿2020/02/26 14:43

編集2020/02/27 06:14

調べて色々いじってみたのですがわからないので質問させてください。

こちらのtp_113というテンプレートを使って、サイドバーを追従する形(position: styicky)にしたいのですがうまくいきません。

自分で追加したコードはhtmlの<div id="sub">部分に

html

1<div id="sub"> 2 3<nav class="box1"> 4<h2>Contents</h2> 5<ul class="submenu"> 6<li><a href="company.html">会社概要</a></li> 7<li><a href="link.html">リンク</a></li> 8<li><a href="contact.html">お問い合わせ</a></li> 9<li><a href="#">メニューサンプル</a></li> 10<li><a href="#">メニューサンプル</a></li> 11</ul> 12</nav> 13 14<div class=“sticky”> 15〜追従する要素〜 16</div> 17 18</div> 19<!--/#sub--> 20

っという感じで追加(他のサブメニューは必要なかったので削除しました)

CSSは**/*subコンテンツ**の一番下に

CSS

1.sticky { 2 position: -webkit-sticky; 3 position: sticky; 4 top: 10px; 5}

を追加しました。

overflow:hiddenが複数あるので、それが原因だと思うのですが、そこからがわからなくて困ってます。
そもそもこのテンプレートを使って追従形にするのは、初心者には無理があるのでしょうか?

ご教示のほどよろしくお願い致します

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

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

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

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

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

hwatarig

2020/02/26 15:45

うまくいっていないもので構いませんので、ご自身で書かれたソースコードを質問文に追加してください。
hwatarig

2020/02/27 00:39

テンプレートのどこにdiv.stickyを追加したのかを質問文に記載してください。
guest

回答1

0

ベストアンサー

overflow:hiddenが複数あるので、それが原因だと思うのですが、

お察しの通り、stickyは先祖要素にoverflow:hidden;がかかっていると動作しませんので、<div class=“sticky”>の全ての先祖要素からoverflow:hidden;を取り除いてください。

次に、<div class="sticky">を入れている<div id="sub">ですが、position:sticky;は直接の親要素のエリアでしか追従しない仕様なので、このままでは高さが足りません。ためしに<div id="sub">height:1000px;など適当な高さを指定してみると、そのエリア内で追従することを確認できると思います。

おそらく、ページを一番下までスクロールしてもずっとついてくるようにしたいとお考えかと思いますので、<div class="sticky"><div id="sub">の子要素から取り出して、<div id="contents" class="inner">の直下に移動するのが良いと思います。ただし、floatしている要素にposition:sticky;を当てるばあい、floatがclearfixされている必要がありますので、<div id="contents" class="inner">にclearfixのスタイルを当ててください。

参考
position: sticky;の仕組みや実際の使い方をやさしく解説

投稿2020/02/27 09:42

hwatarig

総合スコア461

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

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

panisyo

2020/02/27 13:23

詳しい回答ありがとうございます! overflow:hiddenを全てoverflow: visibleに変更し、CSSの#sub にheight:1000px:を追加してみたのですが、動作しませんでした。 他になにか必要なのでしょうか?お手数おかけしてすみません(汗)
hwatarig

2020/02/27 13:45

style.cssとstyletop.cssの両方に body,html {overflow-x: hidden;} という記述があるので、どちらも削除が必要です。削除しましたか?
panisyo

2020/02/29 07:11

はい、削除しました。 ちょっと自分にはまだ早かったのかもしれません。ここや参考に貼っていただいたHPで勉強したいと思います。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問