提示层被输入框遮挡的主因是z-index层级不足或处于不同stacking context:需确保提示层z-index足够大(如9999)、脱离父级限制挂载至body、避免transform/filter等隐式创建新堆叠上下文的属性,并在移动端聚焦时动态重定位。
z-index 比输入框低,导致被遮挡这是最常见原因:提示层(如 tooltip、popover 或自定义 .hint)的 z-index 值小于其下方输入框(input 或 textarea)父容器的 z-index,或输入框本身设置了较高的层级。
实操建议:
z-index 显式设置为足够大的数(如 9999),且其父级没有 transform、opacity 、will-change 等触发新 stacking context 的属性
z-index,除非必要;若已设,提示层的 z-index 必须更高当提示层和输入框分别处于不同 stacking context(比如一个在 position: relative + z-index: 10 的弹窗里,另一个在 body 下无定位的普通表单中),它们的 z-index 就像“两个平行宇宙”,互不干扰。
实操建议:
body 最外层(例如用 ReactDOM.createPortal 或手动 document.body.appendChild),脱离原 DOM 层级束缚transform: translateZ(0)、filter: blur(0) 等隐式创建 stacking context 的 CSS 属性position: relative + z-index: 1,那整个表单就变成一个 stacking context,此时提示层必须比它高,且不能被它的父级截断移动端尤其明显:软键盘弹出后页面重排,提示层位置计算失效,可能被顶到输入框下方,或因 viewport 缩小而错位。
实操建议:
focus 和 blur 事
件,在输入框聚焦时强制重新定位提示层(调用 updatePosition() 或等效逻辑)position: fixed 做提示层——它在软键盘弹出时容易脱离视口锚点;改用 position: absolute 并绑定到最近的 position: relative 容器(需确保该容器不会随键盘滚动)scrollIntoView({ behavior: 'smooth', block: 'nearest' }) 防止输入框被键盘完全盖住.tooltip {
position: absolute;
z-index: 9999;
/* 避免触发新 stacking context */
transform: none;
filter: none;
will-change: auto;
}提示层真正难搞的不是 z-index 数值本身,而是它被包裹在某个看似无关的 transform 或 opacity 容器里——这时候调再大的 z-index 也没用。