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

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

項目背景

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

遇到問題

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

2、通過上滾下滾來讓底部導航顯示或者因此,安卓上面的瀏覽器都可以,但是蘋果safari會一閃一閃,原因是蘋果safari自動有個彈跳效果,導致事件重復執(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);

}

調用方法:

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);

}

調用方法:

  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;

      }

    }

 });

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

其實我上面的函數中已經有判斷,下面再列一下!看如下函數!

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("我到頭部了");

      }

 }

調用方法:

$(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;  //滾動到的當前位置

    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() 

});?

更多信息請查看網絡編程

2025國考·省考課程試聽報名

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