美文网首页
sticky妙用之官网视觉差滚动实现

sticky妙用之官网视觉差滚动实现

作者: 硅谷干货 | 来源:发表于2021-12-03 10:10 被阅读0次

本项目是用vue3做一个炫酷的类苹果官网的项目,很多地方有视觉差滚动特效,所以首先想到了css3中 sticky属性,因为项目庞大而且是多人参与,所以每个人都是其中一个拆分vue组件中开发,所以需要抽取一个公众的计算方法,对想做的动画步骤进行拆解,能形成统一比较统一效果。

注意

在自定义组件中,内容去外层还需要再包一层div,而且要大于内容区的高度,这时候stikcy才有效果,所以样式部分这样写:

.page-section {
  height: 300vh;
  background-color: white;
}
.stick-box{
  width: 100%;
  // height: 100vh;
  padding: 5.56vh 270px;
  overflow: hidden;
  position: sticky;
  top: 0;
}

重点

然后重点来了,配合sticky的计算方法就派上用场了

// 默认初始值
const defaultV = -10;

// 方式一:推荐
const getScrollRatio = (sectionEl: HTMLElement):number => {
  // 判空处理
  if (!sectionEl) { 
    return defaultV;
  } 
  // 获取窗口滚动条高度
  const scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop; 
  // 获取浏览器可视区的高度
  const clientHeight = document.documentElement.clientHeight || document.body.clientHeight; 
  // section元素的高度
  const elClientHeight = sectionEl.clientHeight; 
  // 距离顶部高度少了一屏的高度 卷起 可视区域 一部分高度,大于等于0
  let ps = Math.floor(sectionEl.offsetTop - clientHeight); 
  ps = ps < 0 ? 0 : ps;
  // 每一个section头部滚动到底部  0 ----> 1的变化
  return (scrollTop - ps) / elClientHeight; 
}

// 方式二:次推荐
const getScrollProgress = (sectionEl: HTMLElement):number => {
  // 判空处理
  if (!sectionEl) { 
    return defaultV;
  } 
  // const remommendPageDom =  document.getElementById('remommendPage');
  let windowInnerHeight = window.innerHeight;
  let domOffsetHeight = sectionEl.offsetHeight;
  let domClientRectTop = sectionEl.getBoundingClientRect().top;
  return (windowInnerHeight - domClientRectTop) / domOffsetHeight;
} 

// 方式三:普通
const getScrollRate = (sectionEl: HTMLElement):number => {
  // 判空处理
  if (!sectionEl) { 
    return defaultV;
  } 
  
  // 视口高度
  const innerHeight = window.innerHeight
  // 获取滚动位置
  const scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop
  // 自身内容的高度
  // const offsetHeight = sectionEl.offsetHeight;
  // 获取dom偏移量
  const offsetTop = sectionEl.offsetTop;
  // 从rect中获取元素的高度
  const { height: rectHeight } = sectionEl.getBoundingClientRect();
  // 获取粘性高度H值和粘性Y值
  const stickyH = rectHeight - innerHeight;
  // 滚动的相对位置
  const stickyY = scrollTop - offsetTop;
  // 计算滚动比例
  return stickyY / stickyH;
}

// 设置透明度
const setOpacityCallback = ({ratio,count}, callBack)=> {
  for (let i = 0; i < count; i++) {
    const start = 1 / count * i;
    const end = 1 / count * (i + 1);
    let progress = (ratio - start) / (end - start);
    if (progress >= 1) progress = 1;
    if (progress <= 0) progress = 0;
    callBack && callBack(i, progress);
  }
}

// 对外统一暴露计算位置方法
export const useCalPos = ()=> { 
  return {
    getScrollRatio,
    getScrollProgress,
    getScrollRate,
    setOpacityCallback
  }
}

使用

在监听滚动的方法中做个打印试试,是不是你想要的输出

const onScroll = () => {
  const el = document.querySelector(`.page-section`);
  const ratio = getScrollRatio(el);
  const count = opacityList.length;
  setOpacityCallback({ ratio, count }, setOpacity);
};

const setOpacity = (i, progress) => {
  opacityList[i] = progress;
  console.log(i, progress)
};

点赞加关注,永远不迷路

相关文章

  • sticky妙用之官网视觉差滚动实现

    本项目是用vue3做一个炫酷的类苹果官网的项目,很多地方有视觉差滚动特效,所以首先想到了css3中 sticky属...

  • 动效解决方案ChoreographerJS

    一、choreographerJS 一个实现滚动实现复杂动效的库 官网 https://christinecha....

  • sticky

    sticky实现吸顶,元素内滚动吸顶真是太好用了,仔细研究了一下sticky的特性;先来看下兼容性;chrome有...

  • 使用position:sticky实现吸顶效果

    ps:使用sticky实现吸顶,需注意父元素overflow不能设为hidden(设置hidden则无法滚动),且...

  • iOS TableView滚动时的视觉差效果

    前言: 这个TableView滚动的视觉差效果实现起来比较简单, 又非常实用, 可以拿到项目中使用, liceca...

  • CSS3实现滚动视觉差效果

    在网上看到过一个比较有趣的动画效果实现,就趁空闲时间也做着玩玩,顺便回顾下css3的一些相关属性。 1、背景图的相...

  • 自定义table 表头固定

    通过css3新属性position:sticky实现表头固定内容滚动(表格外用div包裹给div一个高度) htm...

  • Android NestedScrolling机制

    一、概述这样一个效果图,我们思考下如何实现 可以看到“Sticky View”滚动到顶部会“固定住”,列表下拉到第...

  • UITableViewCell系列之(三)卡片式列表

    上一篇中介绍了UITableViewCell视觉差滚动效果。本篇文章介绍UITableViewCell的圆角效果,...

  • 类型和位置

    position: sticky; 基于用户的滚动位置来定位。粘性定位的元素是依赖于用户的滚动,在 positio...

网友评论

      本文标题:sticky妙用之官网视觉差滚动实现

      本文链接:https://www.haomeiwen.com/subject/hnepxrtx.html