0

0

CSS如何实现悬浮的通知弹窗在右上角堆叠_通过fixed定位并在JS中累加计算多个弹窗的top位置

P粉602998670

P粉602998670

发布时间:2026-03-17 01:33:11

|

736人浏览过

|

来源于php中文网

原创

fixed弹窗叠在同一位置因均用固定top值且不参与文档流;需JS动态计算每个弹窗的top,基于已存在弹窗的实际高度与间距累加,并排除正在关闭的节点,确保DOM顺序、视觉状态与布局同步。

css如何实现悬浮的通知弹窗在右上角堆叠_通过fixed定位并在js中累加计算多个弹窗的top位置

fixed定位弹窗为什么总叠在同一个位置

因为所有弹窗都用 top: 20px 这类固定值,浏览器不会自动避让。position: fixed 是相对于视口的绝对定位,不参与文档流,彼此之间毫无感知——你加十个,它们全挤在 top: 20px 那条线上。

真正要堆叠,得靠 JS 动态算每个弹窗的 top 值,让后一个比前一个往下挪一段距离(比如弹窗高度 + 间距)。

  • 别用 CSS 动画或 transition 控制堆叠顺序,那只是视觉错觉,DOM 顺序和定位值没变
  • 弹窗 DOM 节点必须按显示顺序追加到 body 末尾,否则 JS 拿 document.querySelectorAll('.toast') 会漏掉或顺序错乱
  • 高度不能写死:用 getBoundingClientRect().height 读真实渲染高,避免 padding/margin/border 导致计算偏移

JS里怎么安全累加top值

关键不是“加多少”,而是“加给谁”和“加几次”。常见错误是每次 show() 都遍历全部弹窗重算 top,结果旧弹窗被反复修改、动画跳动、z-index 错乱。

正确做法是:只算新弹窗自己的 top,基于当前已存在的弹窗数量和它们的实际高度推导。

立即学习前端免费学习笔记(深入)”;

  • 维护一个全局计数器(如 window.toastCount)不可靠——弹窗可能手动关闭,计数易不同步
  • 应实时查 DOM:const toasts = document.querySelectorAll('.toast:not(.closing)'),排除正在 fade-out 的节点
  • 逐个读 toast.getBoundingClientRect().height 并累加,再加统一间距(如 12px),作为新弹窗的 top
  • 示例逻辑:
    const offset = [...toasts].reduce((sum, t) => sum + t.getBoundingClientRect().height + 12, 0);<br>newToast.style.top = `${offset}px`;

滚动时右上角弹窗为啥会“漂移”

position: fixed 本该锚定视口,但如果父容器有 transformperspectivewill-change,就会创建新的 containing block,导致 fixed 脱离视口,转而相对那个父容器定位。

Flowith
Flowith

一款GPT4驱动的节点式 AI 创作工具

下载

典型场景:用了 antd / element-plus 的 DrawerModal,或自己写了带 transform: translateZ(0) 的 wrapper。

  • 检查弹窗父级是否有任何 transform 值(包括 translateX(0) 这种看似无害的)
  • 用 Chrome DevTools 的 “Layers” 面板看弹窗是否被包进某个合成层(Composited Layer)
  • 强制修复方式:给弹窗加 style="transform: translateZ(0)" 可能反而恶化问题;更稳的是确保弹窗直接挂载到 document.body,且 body 上没有触发新 containing block 的样式

多个弹窗同时关闭时堆叠错乱怎么办

关闭动画(如 opacity: 0 + transition)进行中时,JS 仍把它当有效弹窗算进高度,但视觉上它已收缩或透明,造成后续弹窗位置悬空。

本质是 DOM 存在性、视觉可见性、布局占用三者不同步。

  • 不要等 transitionend 再从 DOM 删除节点——太慢,堆叠计算已出错
  • 关闭时立刻加 class(如 .toast.closing),并在 JS 计算时过滤掉:document.querySelectorAll('.toast:not(.closing)')
  • CSS 中用 .closing { pointer-events: none; opacity: 0; transform: translateY(-10px); },既保持占位(避免重排闪动),又明确标记状态
  • 动画结束后用 setTimeout(() => el.remove(), 300) 清理 DOM(300 对应 transition duration)

堆叠逻辑本身不复杂,难的是把 DOM 状态、CSS 渲染周期、JS 执行时机这三件事对齐。稍有错位,用户就看到弹窗互相穿透、位置跳变、关不干净——这些都不是定位写错了,是生命周期没管住。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1082

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

851

2023.11.06

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1082

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

851

2023.11.06

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

565

2023.09.20

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

931

2024.01.03

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 1.0万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号