欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

原生js实现类似fullpage的单页/全屏滚动

程序员文章站 2022-06-20 19:06:08
前言 单页/全屏滚动页面越来越常见了,它多用于产品介绍、招聘等内容较少的简单页面。针对这种效果也出现了不少 jquery 插件,本文实现的效果类似于fullpage的单屏...

前言

单页/全屏滚动页面越来越常见了,它多用于产品介绍、招聘等内容较少的简单页面。针对这种效果也出现了不少 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;
 };
});

在线演示请点击这里

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。