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

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

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

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

CSS

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

Q&A

解決済

1回答

3259閲覧

slideToggle(display:none/show)でスクロールを調整する方法

maguzo

総合スコア57

jQuery

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

CSS

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

0グッド

0クリップ

投稿2018/04/07 15:22

下記のコードのように、footerはposition:stickyにより画面をスクロールしても
section内のbottom:20pxで表示されるように固定されております。

一方で、<span>footer</span>をクリックすると#footer_extraが
表示されるようになります。

ここで、#footer_extraをどのスクロール位置でも表示させたいのですが
うまくできません。具体的には定時のコードのように、stickyのpositionをとっているのに
例えばsectionの真ん中らへんで<span>footer</span>をすると下に見切れてしまいます。

やりたいこととしては
1)どこのスクロール位置でも
2)#footerは下部に固定配置されており
3)<span>footer</span>をクリックして表示される
4)#footer_extraは他の要素に影響されずすべて表示される、つまり
どのスクロール位置でもクリックしても#footer_extraはすべての範囲が表示され、<span>footer</span>要素を除いては、要素が押し出されて表示されない

ようにしたいと考えております。
他の要素をスクロール上、固定にするのであれば、モーダルウィンドウでも良いというご意見もあるかと思いますが、<span>footer</span>をタブのように使用したいので、slideToggleで実現したいと考えております。

ご助言をいただければ幸いです。

JSFiddle

html

1<!DOCTYPE html> 2<html lang="en" dir="ltr"> 3 <head> 4 <meta charset="utf-8"> 5 <title></title> 6 </head> 7 <body> 8 <section> 9 <div class="content">content_1</div> 10 <div class="content">content_2</div> 11 <div class="content">content_3</div> 12 <div id="footer"> 13 <span>footer</span> 14 <div id="footer_extra">added</div> 15 </div> 16

css

1section{ 2 height:350px; 3 background-color:red; 4} 5.content{ 6 margin: 0 auto; 7 width:100%; 8 height:90px; 9 margin-bottom:5px; 10 background-color:blue; 11} 12 13#footer{ 14 margin: 0 auto; 15 width:100%; 16 height:20px; 17 background-color:#fff000; 18 position:sticky; 19 bottom:20px; 20} 21#footer_extra{ 22 display:none; 23 width:100%; 24 height:100px; 25 background-color:pink; 26 z-index:100; 27}

Javascript

1$(function(){ 2 $('#footer').on('click',function(){ 3 $('#footer_extra').slideToggle('slow'); 4 }) 5})

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

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

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

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

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

guest

回答1

0

ベストアンサー

footer_extraがposition:stickyされたfooter内にあるからですよ

投稿2018/04/08 01:13

Dot

総合スコア120

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

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

maguzo

2018/04/08 06:02

コメントいただきありがとうございます。 ご指摘に点も検討してみたのですが、 <section> <div class="content">content_1</div> <div class="content">content_2</div> <div class="content">content_3</div> <div id="footer"> <span>footer</span> </div> <div id="footer_extra">added</div> </section> のようにこれをfooter外に置くと上の方にスクロール位置がある場合に footer_extraが下部に取り残されてしまい、どのスクルール位置でも 表示されることが実現されなくなってしまいます
Dot

2018/04/08 06:31

いえ footer内にあるので bodyの高さが変わります 伸びた分footerの位置かbodyの位置を調整する必要があるのではないでしょうか
maguzo

2018/04/08 06:39

コメントありがとうございます。 footerのheightを100%に変更したらできました! 位置を調整するというのは親要素の高さを可変すると解釈しました。 CSSについて、まだまだ初心者であるため、親要素が固定で動的に加えられた要素がその大きさを超える場合など、挙動を少し確認してみようとお思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問