首頁 >web前端 >前端問答 >jquery全螢幕滾動不使用插件

jquery全螢幕滾動不使用插件

王林
王林原創
2023-05-18 20:31:10469瀏覽

隨著網路技術的不斷發展,越來越多的網站採用全螢幕滾動效果,使得使用者可以在一個頁面內瀏覽多個內容區域。而實現這種效果的方法有很多種,其中比較常用的是使用jQuery插件來實現。但今天我要介紹的是在不使用jQuery插件的情況下實現全螢幕滾動的方法。

  1. HTML結構

我們首先需要確定我們網站的HTML結構。在本例中,我們將採用一張圖片作為第一屏的背景,而第二屏將顯示一段文字。因此我們的HTML結構應為:

<body>
  <div class="section section-1">
    <div class="bg-img"></div>
  </div>
  <div class="section section-2">
    <div class="text"></div>
  </div>
</body>

可以看出,我們將整個頁面分為兩個部分,每個部分都是一個section,其中第一屏的背景是一個帶有.bg- img類別的div,而第二螢幕則包含一個帶有.text類別的div。

  1. CSS樣式

接下來,我們需要為我們的頁面新增樣式。我們需要將頁面的高度設定為瀏覽器視窗的高度,並將每個section的高度設定為100%。同時,我們需要將所有section的位置設定為絕對定位,以便我們後面進行頁面捲動。

html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
}

.section {
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.section-1 {
  background-color: #f9f9f9;
}

.bg-img {
  background-image: url('https://picsum.photos/1920/1080');
  background-size: cover;
  background-position: center;
  height: 100%;
}

.section-2 {
  background-color: #fff;
}
  1. JavaScript程式碼

現在我們需要為我們的網站新增JavaScript程式碼,以實現頁面的捲動。我們可以使用滑鼠滾輪或鍵盤上下箭頭來進行頁面滾動。

var sectionIndex = 0;
var sections = $('.section');
var totalSections = sections.length;

$(document).on('mousewheel DOMMouseScroll', function (e) {
  if (e.originalEvent.wheelDelta > 0 || e.originalEvent.detail < 0) {
    //向上滚动
    sectionIndex--;
  } else {
    //向下滚动
    sectionIndex++;
  }
  if (sectionIndex < 0) {
    sectionIndex = 0;
  }
  if (sectionIndex > totalSections - 1) {
    sectionIndex = totalSections - 1;
  }
  scrollToSection(sectionIndex);
});

$(document).keydown(function (e) {
  switch (e.which) {
    case 38: //向上箭头
      sectionIndex--;
      break;
    case 40: //向下箭头
      sectionIndex++;
      break;   
    default:
      return; 
  }
  if (sectionIndex < 0) {
    sectionIndex = 0;
  }
  if (sectionIndex > totalSections - 1) {
    sectionIndex = totalSections - 1;
  }
  scrollToSection(sectionIndex);    
});

function scrollToSection(sectionIndex) {
  $('html, body').animate({
    scrollTop: sections.eq(sectionIndex).offset().top
  }, 500);
}

我們定義了一個sectionIndex變數來記錄目前所處的螢幕位置,用於後續進行捲動,同時也定義了sections變數來儲存所有的section元素,totalSections變數用於記錄section數量。

接下來,我們為滑鼠滾輪和鍵盤上下箭頭添加事件監聽器,當用戶進行滾動操作時,我們會將sectionIndex增加或減少,並且檢查sectionIndex的值是否超過了總螢幕數,以確保我們所在的螢幕是合法的。最後,我們呼叫scrollToSection函數去跳到目標畫面。

scrollToSection函數使用jQuery的animate方法來平滑捲動到指定section的位置。我們也可以根據需要修改滾動時間。

  1. 成果展示

最後,我們已經成功地實現了一個不需要使用jQuery插件的全螢幕滾動效果。效果如下:

  1. 總結

#在本文中,我們介紹如何使用純JavaScript和jQuery來實現全螢幕滾動效果,同時也示範了實現效果。雖然jQuery插件可以讓實作更簡單,但使用原生JavaScript可以讓我們更能理解程式碼背後的工作原理和邏輯,同時也讓我們更靈活地自訂滾動效果。

以上是jquery全螢幕滾動不使用插件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn