position: sticky; 网页吸顶效果,吸顶不遮盖容器滚动条

文章目录

  • 一、效果
  • 二、创建容器
  • 三、监听滚动,切换 position
  • 四、引用 js 变量
  • 五、总结

一、效果

  1. 吸顶元素跟随页面向上滚动而滚动,达到一定高度后吸附在容器顶部;
  2. 容器向下滚动到一定高度后,吸顶元素不再吸附,并跟随滚动条向下滚动。
    在这里插入图片描述

二、创建容器

.home-wrapper: 外部容器
.lingxi-fixed: 吸顶元素
.container : 页面的其它内容

<div ref="scrollRef" class="home-wrapper"><section class="lingxi-fixed">...</section><div class="container">...</div>
</div>            

三、监听滚动,切换 position

  1. 监听容器滚动事件,切换吸顶元素的 position 属性,达到吸顶效果
  2. throttle 为 lodash 节流函数,减少页面的重绘
import { throttle } from 'lodash-es';const scrollRef = ref();
// CSS 盒子
const cssBox = reactive({lingxiPosition: 'static',lingxiTop: '0',
});// 监听滚动
const homeScrollEven = throttle((e: any) => {if (scrollRef.value.scrollTop > 106) {cssBox.lingxiPosition = 'sticky';cssBox.lingxiTop = '-106px';} else {cssBox.lingxiPosition = 'static';cssBox.lingxiTop = '0';}
}, 200);onMounted(() => {scrollRef.value.addEventListener('scroll', homeScrollEven, false);
});onBeforeUnmount(() => {scrollRef.value.removeEventListener('scroll', homeScrollEven, false);
});

四、引用 js 变量

  1. 样式使用 SCSS 框架,引用 js 变量,而不直接操作元素。
.home-wrapper {width: 100%;height: 100%;overflow-y: auto;
}
.lingxi-fixed {--lingxiPosition: v-bind(cssBox.lingxiPosition);--lingxiTop: v-bind(cssBox.lingxiTop);width: 100%;z-index: 10;box-sizing: border-box;padding: 10px 80px;background-color: #f9f9fb;box-shadow: #f9f9fb 0px 5px 10px;position: var(--lingxiPosition);top: var(--lingxiTop);
}

五、总结

  1. 元素吸顶效果,依赖于 position: sticky fixed 浮动属性;
  2. 监听容器滚动,判断容器的 scrollTop 值是否到达阈值。在阈值边界切换 position 属性;
  3. position: stickyfixed 两者都能在文档流中表示浮动,其它属性值(如 top)设置也相似。不同的是 fixed 相对于 <body> 元素浮动。而 sticky 相对父元素浮动。通常情况,<body> 容器内的元素设置了 fixed ,会遮盖容器的滚动条。设置sticky 属性不会出现这种情况。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/39722.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何选择适合自己的巴比达内网穿透方案

选择适合自己的巴比达内网穿透方案&#xff0c;需要考虑几个关键因素&#xff0c;包括您的具体需求、安全性要求、技术水平以及预算。以下是一些选择巴比达内网穿透方案的建议步骤&#xff1a; 1. 确定需求和用途 首先&#xff0c;需要明确您希望通过内网穿透实现的具体目标和…

CesiumJS【Basic】- #053 绘制渐变填充多边形(Entity方式)-使用canvas

文章目录 绘制渐变填充多边形(Entity方式)-使用canvas1 目标2 代码2.1 main.ts绘制渐变填充多边形(Entity方式)-使用canvas 1 目标 使用Entity方式绘制绘制渐变填充多边形 - 使用canvas 2 代码 2.1 main.ts import * as Cesium from cesium;const viewer = new Cesium…

量变引发质变,云微客AI矩阵系统以量取胜

我不允许还有老板在买大量的手机做矩阵&#xff0c;其实只需要一套云微客AI矩阵系统&#xff0c;就可以同时运营上百个矩阵账号。不需要买很多手机&#xff0c;也不用招很多运营人员来写文案、剪视频&#xff0c;AI矩阵系统自带智能创作、智能剪辑等功能&#xff0c;只需要上传…

java设计模式(五)建造者模式(Builder Pattern)

1、模式介绍&#xff1a; 建造者模式&#xff08;Builder Pattern&#xff09;是一种创建型设计模式&#xff0c;它允许你创建一个复杂对象的表示&#xff0c;同时隐藏了创建细节。该模式将对象的构建过程和表示分离&#xff0c;使得相同的构建过程可以创建不同的表示。 2、应…

零基础入门GIS开发,必看实用教程【附智慧校园实战笔记源码】

GIS开发也叫webgis&#xff0c;web就是指网页端&#xff0c;所以GIS开发大部分情况下是指网页端的地图可视化开发。 因此GIS开发需要学习前端开发HTML/CSS/JS&#xff0c;以及一些常见的前端框架&#xff0c;例如vue和react等&#xff08;新中地教育通常是教vue&#xff0c;其…

ssm三农产品助推网站-计算机毕业设计源码91990

目录 摘要 1 绪论 1.1选题背景与意义 1.2国内外研究现状 1.3论文结构与章节安排 2网站分析 2.1 可行性分析 2.2 网站流程分析 2.2.1 数据流程 2.2.2 业务流程 2.3 网站功能分析 2.3.1 功能性分析 2.3.2 非功能性分析 2.4 网站用例分析 2.5本章小结 3 网站总体设…

这次发现的开源版本我愿意称之为最具学习价值的商城系统|商城源码点击进入

这是一款我发现的强大、灵活、易用的商城系统&#xff0c;成为我的的首选商城框架&#xff0c;让我的商城开发事半功倍&#xff01;这款开源商城项目具有多元的商业模式满足了任何使用场景的需求。 有S2B2C供应链商城、B2B2C多商户商城、O2O外卖商城、B2C单商户商城、社区团购、…

Hive查询优化 - 面试工作不走弯路

引言&#xff1a;Hive作为一种基于Hadoop的数据仓库工具&#xff0c;广泛应用于大数据分析。然而&#xff0c;由于其依赖于MapReduce框架&#xff0c;查询的性能可能会受到影响。为了确保Hive查询能够高效运行&#xff0c;掌握查询优化技巧至关重要。在日常工作中&#xff0c;高…

Python入门 2024/7/3

目录 for循环的基础语法 遍历字符串 练习&#xff1a;数一数有几个a range语句 三个语法 语法1 语法2 语法3 练习&#xff1a;有几个偶数 变量作用域 for循环的嵌套使用 打印九九乘法表 发工资案例 continue和break语句 函数的基础定义语法 函数声明 函数调用 …

使用CiteSpace软件对知网文献进行关键词共现/聚类/突现分析

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

前端进阶全栈计划:Spring扫盲

Spring扫盲 spring 和 springboot的关系? 类比前端&#xff1a;vue.js和nuxt.js的关系 Spring Boot 是基于 Spring 框架的快速开发工具&#xff0c;简化了 Spring 应用的配置和部署。 spring核心特性 1. 依赖注入 依赖注入是Spring框架的核心功能之一。它允许你通过配置将对…

Windows系统安装MySQL8.0.38

MySQL 8.0 相对于 MySQL 5.7 来说有几个显著的区别和改进&#xff0c;以下是一些主要的区别&#xff1a; JSON 数据类型和函数改进&#xff1a; MySQL 8.0 引入了更多的 JSON 支持&#xff0c;包括 JSON 数据类型、JSON 函数和操作符。这使得存储和查询 JSON 数据更加方便和高效…

从头开始构建 RAG 的 LLM 代理:综合指南

GPT-3、GPT-4 等 LLM 及其开源版本经常难以检索最新信息&#xff0c;有时会产生幻觉或不正确的信息。 检索增强生成 (RAG)是一种将 LLM 的强大功能与外部知识检索相结合的技术。RAG 使我们能够将 LLM 响应建立在事实、最新的信息之上&#xff0c;从而显著提高 AI 生成内容的准…

还敢乱买智能猫砂盆?今天扒一扒糯雪、鸟语花香、CEWEY智能猫砂盆!

在这高科技迅速发展的时代&#xff0c;连猫咪用来拉屎的屎盆子也变成了全自动化&#xff0c;从普通的猫砂盆变成了智能猫砂盆&#xff0c;让铲屎官再也不用每天赶回家铲屎给猫整理烂摊子&#xff0c;实在是非常轻松。所以那个时候的我也果断扔掉了家里的猫砂盆&#xff0c;转而…

电子电路学习笔记(4)三极管

部分内容参考链接&#xff1a; 电子电路学习笔记&#xff08;5&#xff09;——三极管_三极管 箭头-CSDN博客 模拟电子技术基础笔记&#xff08;4&#xff09;——晶体三极管_集电结的单向导电性-CSDN博客 硬件基本功-36-三极管Ib电流如何控制Ic电流_哔哩哔哩_bilibili MOS…

使用DC/AC电源模块时需要注意的事项

BOSHIDA 使用DC/AC电源模块时需要注意的事项 1. 仔细阅读和理解产品说明书&#xff1a;在使用DC/AC电源模块之前&#xff0c;应该仔细阅读和理解产品说明书&#xff0c;了解其性能特点、技术要求和使用方法&#xff0c;以确保正确使用和避免潜在的安全风险。 2. 选择适当的电…

源代码编译安装LAMP

Apache简介 主要特点 开放源代码&#xff0c;跨平台应用 支持多种网页编程程序 模块化设计&#xff0c;运行稳定&#xff0c;良好得安全性 软件版本 1.X 目前最高版本是1.3&#xff0c;运行稳定 向下兼容性较好&#xff0c;但缺乏一些较新得功能 2.X 目前最高版本是2.4 …

PDF处理篇:如何调整 PDF 图像的大小

将视觉效果无缝集成到 PDF 中的能力使它们成为强大的通信工具。然而&#xff0c;笨拙的图像大小会迅速扰乱文档的流程&#xff0c;阻碍清晰度和专业性。幸运的是&#xff0c;GeekerPDF 和Adobe Acrobat等流行的应用程序提供了用户友好的解决方案来应对这一挑战。这个全面的指南…

Google 发布了最新的开源大模型 Gemma 2,本地快速部署和体验

Gemma 2 是 Google 最新发布的开源大语言模型。它有两种规模&#xff1a;90 亿&#xff08;9B&#xff09;参数和 270 亿&#xff08;27B&#xff09;参数&#xff0c;分别具有基础&#xff08;预训练&#xff09;和指令调优版本&#xff0c;拥有 8K Tokens 的上下文长度&#…

Vue3 特点以及优势-源码解剖

Vue3 特点以及优势-Vue3.4源码解剖 Vue3 特点以及优势 1.声明式框架 命令式和声明式区别 早在 JQ 的时代编写的代码都是命令式的&#xff0c;命令式框架重要特点就是关注过程声明式框架更加关注结果。命令式的代码封装到了 Vuejs 中&#xff0c;过程靠 vuejs 来实现 声明式代…