如何制作HTML未读消息红点数字标记?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1062个文字,预计阅读时间需要5分钟。
红点要显示9或12,不能依赖+JS+每次改+textContent+再触发生重排,更不宜将数字硬编码进HTML标签内(例如:
常见错误是后端返回 count: 0,前端却没同步清空 data-count,导致红点显示“0”;或者 JS 字符串拼错(如传了 undefined),attr() 就渲染成空字符串,红点变空心圆。务必确保:
• 后端/JS 更新时,同时设置 data-unread 和 data-count
• data-count 值始终为字符串(React 中用 {String(count)},Vue 中用 :attr="{ 'data-count': String(count) }")
• 数字超 99 时,统一设为 "99+",避免宽度撑开错位
overflow: hidden 会吃掉红点,检查父容器的裁剪边界
红点明明写了 top: 0; right: 0; transform: translate(50%, -50%),却只显示一半,甚至完全消失——八成是父容器设置了 overflow: hidden。导航栏、Tab 标签、折叠菜单这些地方特别爱加这个声明,而红点作为 ::after 伪元素,超出父级范围就会被裁掉。
本文共计1062个文字,预计阅读时间需要5分钟。
红点要显示9或12,不能依赖+JS+每次改+textContent+再触发生重排,更不宜将数字硬编码进HTML标签内(例如:
常见错误是后端返回 count: 0,前端却没同步清空 data-count,导致红点显示“0”;或者 JS 字符串拼错(如传了 undefined),attr() 就渲染成空字符串,红点变空心圆。务必确保:
• 后端/JS 更新时,同时设置 data-unread 和 data-count
• data-count 值始终为字符串(React 中用 {String(count)},Vue 中用 :attr="{ 'data-count': String(count) }")
• 数字超 99 时,统一设为 "99+",避免宽度撑开错位
overflow: hidden 会吃掉红点,检查父容器的裁剪边界
红点明明写了 top: 0; right: 0; transform: translate(50%, -50%),却只显示一半,甚至完全消失——八成是父容器设置了 overflow: hidden。导航栏、Tab 标签、折叠菜单这些地方特别爱加这个声明,而红点作为 ::after 伪元素,超出父级范围就会被裁掉。

