原生js實作類別似fullpage的單頁/全屏滾動,jsfullpage全屏

來源:互聯網
上載者:User

原生js實作類別似fullpage的單頁/全屏滾動,jsfullpage全屏

前言

單頁/全屏滾動頁面越來越常見了,它多用於產品介紹、招聘等內容較少的簡單頁面。針對這種效果也出現了不少 jQuery 外掛程式,本文實現的效果類似於fullpage的單屏滾動,使用原生JS實現,不依賴任何js庫;

css代碼:

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

html代碼:

<div style="background:#FEE;"></div><div style="background:#EFE;"></div><div style="background:#EEF;"></div><div style="background:red;"></div>

js代碼:

document.addEventListener("DOMContentLoaded", function() { var body = document.body, html = document.documentElement; var itv, height = document.body.offsetHeight; var page = scrollTop() / height | 0; //視窗大小改變事件 addEventListener("resize", onresize, false); onresize(); //滾輪事件 document.body.addEventListener( "onwheel" in document ? "wheel" : "mousewheel", function(e) {  clearTimeout(itv);  itv = setTimeout(function() {  var delta = e.wheelDelta / 120 || -e.deltaY / 3;  page -= delta;  var max = (document.body.scrollHeight / height | 0) - 1;  if (page < 0) return page = 0;  if (page > max) return page = max;  move();  }, 100);  e.preventDefault(); } ); //平滑滾動 function move() { var value = height * page; var diff = scrollTop() - value; (function callee() {  diff = diff / 1.2 | 0;  scrollTop(value + diff);  if (diff) itv = setTimeout(callee, 16); })(); }; //resize事件 function onresize() { height = body.offsetHeight; move(); }; //擷取或設定scrollTop function scrollTop(v) { if (v == null) return Math.max(body.scrollTop, html.scrollTop); else body.scrollTop = html.scrollTop = v; };});

線上示範請點擊:這裡

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的協助,如果有疑問大家可以留言交流。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.