首頁 > web前端 > js教程 > 如何在不使用 jQuery 的情況下確定 JavaScript 中的滾動方向?

如何在不使用 jQuery 的情況下確定 JavaScript 中的滾動方向?

DDD
發布: 2024-10-28 03:49:01
原創
1103 人瀏覽過

How Can I Determine Scroll Direction in JavaScript Without Using jQuery?

不使用 jQuery 確定滾動方向

偵測滾動方向

無需依賴 jQuery 即可實現確定滾動事件的方向。這是一個 JavaScript 實作:

<code class="javascript">var lastScrollTop = 0;

// Adjust the element selector based on the target of your scroll event.
document.querySelector('body').addEventListener("scroll", function() {
   var st = window.pageYOffset || document.documentElement.scrollTop;
   if (st > lastScrollTop) {
      // Downscroll code
   } else if (st < lastScrollTop) {
      // Upscroll code
   }
   lastScrollTop = st <= 0 ? 0 : st; // Account for negative scrolling or devices with touch events
}, false);</code>
登入後複製

在此程式碼中:

  • lastScrollTop 儲存上一個捲動位置。
  • 滾動事件偵聽器追蹤目前滾動位置st.
  • 透過比較st和lastScrollTop,可以判斷滾動方向。
  • 向下捲動時執行if語句,向上捲動時執行else if語句。
  • 將lastScrollTop更新為目前滾動位置,為下一個滾動事件做準備。

避免使用「返回頂部」按鈕

而不是添加「返回頂部」按鈕,您可以透過偵測滾動方向來採用更平滑的方法。例如,您可以:

  • 顯示浮動導覽欄,向下捲動時可見,向上捲動時隱藏。
  • 使用 CSS 動畫隨著頁面的變化顯示或淡出元素滾動。
  • 根據捲動方向調整頁面上元素的不透明度,創造視差效果。

以上是如何在不使用 jQuery 的情況下確定 JavaScript 中的滾動方向?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板