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

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

ただいまの
回答率

87.49%

fullpage.jsを用いてるページでのフッターナビでのページ内リンク

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 4,897

score 25

前提・実現したいこと

お世話になっております、表題のとおりではございますが、
fullpage.jsを用いてページを作成しております。
ページとしましては、
① まず画面一面に背景に指定した画像とテキストが表示されます。
② ①の画面から下へスクロールすると、そのページのコンテンツ(内容A、内容B、内容C)が表示されます。
※fullpage.jsを用いているのは①から下へ移動するときのみで、それ以降は通常のスクロールになっております。
③ 画面最下部にフッターナビを固定で表示しており、そのナビには(内容A、内容B、内容C)といったページ内リンク用の項目があります。
フッターナビを押されると、ページ内リンクでぬるぬるっとその内容のところまで移動するようにしたいです。
また、コンテンツ画面の最上部まで来たときに上へスクロールすると①の画面に戻るようにしたいです。

発生している問題・エラーメッセージ

fullpage.jsと
http://weback.net/javascript/1022/のサイトを参考に作成したページ内リンク用スムーススクロールjavascriptをインクルードすると
干渉をしてしまっているのかページ内リンクが効かない。

ソースコード

<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>タイトルタイトル</title>
<link rel="stylesheet" href="css/init.css">
<link rel="stylesheet" href="css/jquery.fullPage.css">
<link rel="stylesheet" href="style.css">
<!--[if lt IE 9]>
<script src="js/html5shiv.js"></script>
<![endif]-->
<!--[if lt IE 9]>
<script src="js/css3-mediaqueries.js"></script>
<![endif]-->
<script src="js/jquery-1.11.1.min.js"></script>
<script src="js/jquery.easings.min.js"></script>
<script src="js/jquery.slimscroll.min.js"></script>
<!--ページ内リンクのスムーススクロールのために作成したjs(コード別途記述)-->
<script src="js/test.js"></script>
<script src="js/jquery.fullPage.js"></script>
<script type="text/javascript">
$(document).ready(function() {
    $('#fullpage').fullpage({
            scrollOverflow: true,
            css3: false
    });
});
</script>
<script type="text/javascript">
 $(document).ready(function() {
  $("#next").click(function () {
   $.fn.fullpage.moveTo(2);
  });
 });
</script>
</head>

<body id="temp01">
<header>
    <div class="wrapper01">
        <div class="wrapper02">
            <h1 class="logo"><a href=""><img src="images/logo.png" alt="テストページ"></a></h1>
        </div>
    </div>
</header>
<footer>
    <div class="wrapper01 footernavi02">
        <div class="wrapper02">
            <ul>
                <li><a onclick="scrollup(); return false;" href="#test1"><span>test1へ</span></a></li>
                <li><a onclick="scrollup(); return false;" href="#test2"><span>test2へ</span></a></li>
                <li><a onclick="scrollup(); return false;" href="#test3"><span>test3へ</span></a></li>
                <li><a onclick="scrollup(); return false;" href="#test4"><span>test4へ</span></a></li>
            </ul>
        </div>
    </div>
</footer>
<div id="fullpage">
    <div class="section mainimg">
        <div class="slide">
            <h1>メイン画像見出</h1>
            <p>メイン画像テキスト<br> <br> </p>
        </div>
    </div>
    <div class="section section01">
        <div class="wrapper01">
            <div class="wrapper02">
                <div class="wrapper03">
                    <div id="test1" class="wrapper04 box_a">
                        <h2>ボックスA</h2>
                        <p>コンテンツコンテンツコンテンツコンテンツコンテンツコンテンツコンテンツコンテンツ</p>
                        <p class="c_note">テキスト</p>
                    </div>
                    <div id="test2" class="wrapper04 box_b">
                        <h2>ボックスB</h2>
                        <p>コンテンツコンテンツコンテンツコンテンツコンテンツコンテンツコンテンツコンテンツ</p>
                        <p class="c_note">テキスト</p>
                    </div>
                    <div id="test3" class="wrapper04 box_c">
                        <h2>ボックスC</h2>
                        <p>コンテンツコンテンツコンテンツコンテンツコンテンツコンテンツコンテンツコンテンツ</p>
                        <p class="c_note">テキスト</p>
                    </div>
                    <div id="test4" class="wrapper04 box_d">
                        <h2>ボックスD</h2>
                        <p>コンテンツコンテンツコンテンツコンテンツコンテンツコンテンツ</p>
                        <p class="c_note">テキスト</p>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>
</body>
</html>

/////test.js/////
var up_timer;
 
function getPosition(){
    horizontal = document.body.scrollLeft || document.documentElement.scrollLeft;
    vertical = document.body.scrollTop  || document.documentElement.scrollTop;
}
 
function pageup(x,y){
    if (up_timer) {
        clearTimeout(up_timer);
    }
    if (y >= 1) {
        getPosition();
        var divisionY = (vertical-(vertical/7));
        var Y = Math.floor(divisionY);
        window.scrollTo(horizontal,Y);
        up_timer = setTimeout("pageup("+horizontal+","+Y+")",10);
    } else {
        window.scrollTo(horizontal,0);
        clearTimeout(up_timer);
    }
}
 
function scrollup(){
    getPosition();
    pageup(horizontal,vertical);
}

補足情報

<li><a onclick="scrollup(); return false;" href="#test1"><span>test1へ</span></a></li>
の部分の[onclick="scrollup(); return false;"]を削除するとページ内リンクはそのまま利用できます(当然だとは思いますが・・・)

ご助力いただければと思います。
宜しくお願いします。
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

0

参考にされているサイトがでたらめです。

demoのあるサイトを参考にされたほうが良いかと思います。
http://memocarilog.info/jquery/7236

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

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

関連した質問

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