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;需要明确您希望通过内网穿透实现的具体目标和…

JavaScript中arguments 对象与剩余参数(Rest Parameters)

在JavaScript中&#xff0c;arguments 对象是一个类数组对象&#xff0c;它包含了函数被调用时传递给函数的所有参数。这个对象允许你在函数内部访问传递给函数的参数&#xff0c;而无需在函数定义时显式地声明它们。这在处理不确定数量参数的情况下特别有用&#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;只需要上传…

新型开发语言的试用感受-仓颉语言发布之际

经常听一些媒体介绍一些新型的开发语言&#xff0c;所以最近心血来潮&#xff0c;安装了几种感受了一些。 先看名气&#xff0c;如ziglang&#xff0c;网址为&#xff1a;Home ⚡Zig Programming Language 号称是可以取代C语言的一门新语言&#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 网站总体设…

爬虫笔记0

问题梳理: <dl>&#xff1a;Definition List&#xff08;定义列表&#xff09; <dt>&#xff1a;Definition Term&#xff08;一般放标题&#xff09; <dd>&#xff1a;Definition Description&#xff08;定义列表项&#xff0c;数据所在&#xff09; &l…

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

这是一款我发现的强大、灵活、易用的商城系统&#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框架的核心功能之一。它允许你通过配置将对…

如何在Java中实现任务调度

如何在Java中实现任务调度 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 任务调度的基础概念 任务调度在软件开发中是一个常见的需求&#xff0c;特别是在需…

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 生成内容的准…

http包详解

http包的作用及使用 go的http包是go的web编程的核心内容&#xff0c;go的web框架本质上都是基于http提供的组件进行再度封装。我们来看一下http基本的使用&#xff1a; func main() {http.Handle("/get", GetVal())http.Handle("/hello", Hello())http.H…

Post请求方式获取亚马逊商品详情数据API(实时更新,缓存数据)

亚马逊商品详情数据接口&#xff08;Amazon Product Advertising API&#xff09;是亚马逊为开发者提供的一种服务&#xff0c;允许他们通过编程方式访问亚马逊网站上的商品信息。这些信息可以包括商品的详细描述、价格、库存状态、客户评价等。以下将详细阐述如何使用亚马逊商…

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

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