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

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

ただいまの
回答率

90.62%

  • jQuery

    6522questions

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

ヘッダーメニューのFixedを使ってタイトルをかぶらせないようにしたい

受付中

回答 0

投稿

  • 評価
  • クリップ 1
  • VIEW 81

Leon-Lionking

score 13

ヘッダーメニューのFixedを使っています。

参考
・ヘッダーメニューの追従
OKU LOG

・ページ内スクロール
Kyasper Web Design キャスパーウェブデザイン

実行したい内容
・ページ内スクロール後、ヘッダーメニューをタイトルにかぶらせないようにしたい

<nav id="headernav" role="navigation">
    <ul class="headermenu">
        <li><a href="#menu01" title="menu01">menu01</a></li>
        <li><a href="#menu02" title="menu02">menu02</a></li>
        <li><a href="#menu03" title="menu03">menu03</a></li>
    </ul>
</nav><!-- # Navigation -->
<section id="menu01">
    <h2>Menu01</h2>
</section>
<section id="menu02">
    <h2>Menu03</h2>
</section>
<section id="menu03">
    <h2>Menu03</h2>
</section>


CSSは割愛させていただきます。

// ヘッダーメニューの追従
$(function() {
    var headNav = $("#headernav");
    //scrollだけだと読み込み時困るのでloadも追加
    $(window).on('load scroll', function (){
        //現在の位置が500px以上かつ、クラスfixedが付与されていない時
        if($(this).scrollTop() > 200 && headNav.hasClass('fixed') == false) {
            //headerの高さ分上に設定
            headNav.css({"top": '-100px'});
            //クラスfixedを付与
            headNav.addClass('fixed');
            //位置を0に設定し、アニメーションのスピードを指定
            headNav.animate({"top": 0},600);
        }
            //現在の位置が300px以下かつ、クラスfixedが付与されている時にfixedを外す
            else if($(this).scrollTop() < 200 && headNav.hasClass('fixed') == true){
            headNav.removeClass('fixed');
        }
    });
});

// ページ内スクロール
$(function(){
    // ヘッダの高さを取得する
    var headerHight = 80;
    // #で始まるアンカーをクリックした場合に処理
    $('a[href^=#]').click(function() {
        // スクロールの速度
        var speed = 400; // ミリ秒
        // アンカーの値取得
        var href= $(this).attr("href");
        // 移動先を取得
        var target = $(href == "#" || href == "" ? 'html' : href);
        // 移動先を数値で取得
        var position = target.offset().top;
        // 高さの位置をずらす( var headerHight の部分を調整 )
        var position = target.offset().top-headerHight;
        // スムーススクロール
        $('body,html').animate({scrollTop:position}, speed, 'swing');
        return false;
    });
});

ページ内スクロールに高さを取得していますが、ヘッダー追従の部分が何故かかぶってしまいます。

ご教授お願いいたします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正の依頼

  • _lemon2003_

    2018/08/26 16:11

    ヘッダー追従の部分が何故かかぶってしまいます。 とは、具体的にどのようなことですか?

    キャンセル

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

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

  • ただいまの回答率 90.62%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • jQuery

    6522questions

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