茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    使用jQuery判斷瀏覽器滾動條位置的方法
    來源:易賢網(wǎng) 閱讀:1071 次 日期:2016-06-17 16:45:43
    溫馨提示:易賢網(wǎng)小編為您整理了“使用jQuery判斷瀏覽器滾動條位置的方法”,方便廣大網(wǎng)友查閱!

    借助jQuery,我們能夠更加輕松地判斷頁面滾動條(scroll)是上滾還是下滾,且是否滾動到頭部或者底部,這里我們就來看一下使用jQuery判斷瀏覽器滾動條位置的方法

    項目背景

    webtouch(webapp)頁面,防蘋果手機safari瀏覽器,網(wǎng)上滑動,底部導(dǎo)航消失,滑動到底部又出現(xiàn)。向下滑動,底部導(dǎo)航出現(xiàn)。

    遇到問題

    1、我一開始用swipeup和swipedown來做,發(fā)現(xiàn)因為有滾動條,不會觸發(fā)。因此只能判斷滾動條是上滾下滾等。關(guān)于手機手勢,后面的文章會介紹,歡迎關(guān)注!

    2、通過上滾下滾來讓底部導(dǎo)航顯示或者因此,安卓上面的瀏覽器都可以,但是蘋果safari會一閃一閃,原因是蘋果safari自動有個彈跳效果,導(dǎo)致事件重復(fù)執(zhí)行,解決辦法是給上滾下滾一個距離,滾動到一定距離后返回是上滾還是下滾。

    單純判斷滾動條方向

    function scroll( fn ) {

      var beforeScrollTop = document.body.scrollTop,

        fn = fn || function() {};

      window.addEventListener("scroll", function() {

        var afterScrollTop = document.body.scrollTop,

          delta = afterScrollTop - beforeScrollTop;

        if( delta === 0 ) return false;

        fn( delta > 0 ? "down" : "up" );

        beforeScrollTop = afterScrollTop;

      }, false);

    }

    調(diào)用方法:

    scroll(function(direction) { console.log(direction) });  

    以上方法手機蘋果瀏覽器事件會跳動,解決方法及代碼改進

    scrollDirect: function (fn) {

      var beforeScrollTop = document.body.scrollTop;

      fn = fn || function () {

      };

      window.addEventListener("scroll", function (event) {

        event = event || window.event;

        var afterScrollTop = document.body.scrollTop;

        delta = afterScrollTop - beforeScrollTop;

        beforeScrollTop = afterScrollTop;

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

        var scrollHeight = $(document).height();

        var windowHeight = $(this).height();

        if (scrollTop + windowHeight > scrollHeight - 10) { //滾動到底部執(zhí)行事件

          fn('up');

          return;

        }

        if (afterScrollTop < 10 || afterScrollTop > $(document.body).height - 10) {

          fn('up');

        } else {

          if (Math.abs(delta) < 10) {

            return false;

          }

          fn(delta > 0 ? "down" : "up");

        }

      }, false);

    }

    調(diào)用方法:

      var upflag=1;

      var downflag= 1;

      //scroll滑動,上滑和下滑只執(zhí)行一次!

    scrollDirect(function (direction) {

        if (direction == "down") {

          if (downflag) {

            $(".footer_wrap").slideUp(200);

            downflag = 0;

            upflag = 1;

          }

        }

        if (direction == "up") {

          if (upflag) {

            $(".footer_wrap").slideDown(200);

            downflag = 1;

            upflag = 0;

          }

        }

     });

    滾動條滾動到底部和頭部判斷

    其實我上面的函數(shù)中已經(jīng)有判斷,下面再列一下!看如下函數(shù)!

    BottomJumpPage: function () {

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

          var scrollHeight = $(document).height();

          var windowHeight = $(this).height();

          if (scrollTop + windowHeight == scrollHeight) { //滾動到底部執(zhí)行事件

              console.dir("我到底部了");

          }

          if (scrollTop == 0) { //滾動到頭部部執(zhí)行事件

          console.dir("我到頭部了");

          }

     }

    調(diào)用方法:

    $(window).scroll(BottomJumpPage);

    判斷div是否滾動到底部

    上面的方法是判斷滾動軸是否滾動到底部,但是有時候,我們在做滾動加載的時候,有時候也要做某個div是否滾動到底部然后加載。那么如何判斷DIV的滾動軸滾動到底部呢?

    這個也需要了解幾個高度:

    1、div的高度 $("#某div").height();

    2、滾動軸的高度 $(#某div)[0].scrollHeight

    3、滾動軸到div頂部的高度 $(某div)[0].scrollTop;

    書寫代碼如下:

    $(document).ready(function (){

        var nScrollHight = 0; //滾動距離總長(注意不是滾動條的長度)

        var nScrollTop = 0;  //滾動到的當(dāng)前位置

        var nDivHight = $("#div1").height();

        $("#div1").scroll(function(){

         nScrollHight = $(this)[0].scrollHeight;

         nScrollTop = $(this)[0].scrollTop;

         if(nScrollTop + nDivHight >= nScrollHight)

          alert("滾動條到底部了");

         });

    });

    PS:jQuery滾動條位置控制:

    將div的滾動條滾動到其子元素所在的位置,方便自動定位。

    var container = $('div'), 

    scrollTo = $('#row_8');

    container.scrollTop( 

    scrollTo.offset().top - container.offset().top + container.scrollTop() 

    );

    // Or you can animate the scrolling: 

    container.animate({ 

    scrollTop: scrollTo.offset().top - container.offset().top + container.scrollTop() 

    });?

    更多信息請查看網(wǎng)絡(luò)編程
    易賢網(wǎng)手機網(wǎng)站地址:使用jQuery判斷瀏覽器滾動條位置的方法

    2026上岸·考公考編培訓(xùn)報班

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)