好程式設計師技術分享jQuery實現類似fullpage外掛的全屏滾動效果

好程式設計師IT發表於2019-04-04

好程式設計師 技術分享 jQuery實現類似fullpage外掛的全屏滾動效果

結合網上的思路,加上我之前自己做的程式碼,程式碼有這幾種功能:

 

1.頭部和尾部的內容可以不用滾動,只要中間的滾動就行。

 

2.支援上一屏和下一屏的動畫觸發

 

3.支援下一頁和上一頁導航跳轉

 

4.支援小導航顯示和跳轉到某一頁

 

HTML程式碼:

 

<div>header</div>

<div>

<div>

<div class="page page1">page1</div>

<div class="page page2">page2</div>

<div class="page page3">page3</div>

<div class="page page4">page4</div>

</div>

<div><i></i><i></i><i></i><i></i></div>

<a href="javascript:void(0)">下一頁</a>

</div>

<div>footer</div>

<script src="

<script src="

CSS設定時,需要注意有兩個父類元素,最外面的要設定超出高度隱藏。

 

.doc{height:640px;position:relative;overflow:hidden}

.main{position:relative}

.doc .page{position:absolute;height:100%;width:100%;top:100%}

.doc.done .page{position:static;top:0}

JS程式碼,要注意滾動的相容程式碼用到了jQuery外掛jquery-mousewheel,不要漏掉這個外掛

JS:

 

$(function() {

    var onScroll = false,

    curIndex = 0,

    len = $(".doc .page").length;

    var winHeight = $(window).height();

    // var boxHeight = winHeight- 60 >640 ? winHeight - 60 : 640; //當需要顯示所有內容,需要給外層一個固定高度,保證所有內容都能看到

    var boxHeight = winHeight - 60;

    var toPage = function(curIndex) {

        onScroll = true;

        var now = -curIndex * boxHeight;

        $(".page").eq(curIndex).addClass("current").siblings(".page").removeClass("current");

        $(".page-nav i").eq(curIndex).addClass("current").siblings("i").removeClass("current");

        $(".main").animate({

            top: now + "px"

        },1000,function() {

            onScroll = false;

        });

    };

    $(".doc").css("height", boxHeight);

    $(".main").css("height", boxHeight * len);

    $(".page").css("height", boxHeight);

    $(".doc").addClass("done");

    var pageNext = function() {

        if (curIndex == len - 1) return;

        curIndex++;

        toPage(curIndex);

    }

    var pagePrev = function() {

        if (curIndex == 0) return;

        curIndex--;

        toPage(curIndex);

    }

    $(".doc").on("mousewheel",function(e, i) {

        if (onScroll) return;

        if (i < -.2) {

            //向下滾動

            pageNext();

        } else {

            //向上滾動

            pagePrev();

        }

    });

    $('.nextPage').on('click',function() {

        if (onScroll) return;

        pageNext();

    });

    $('.page-nav i').on('click',function() {

        if (onScroll) return;

        var index = $(this).index();

        toPage(index);

    })

});


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69913892/viewspace-2640411/,如需轉載,請註明出處,否則將追究法律責任。

相關文章