-
position:sticky失效主因是缺少有效滚动祖先;需确保最近可滚动祖先的overflow-y为auto/scroll且内容溢出,避免hidden、visible或transform干扰,top值受border/padding/transform影响。
-
答案:通过CSS的order属性结合Flexbox与Grid布局,可在不改变HTML结构的前提下,灵活调整子元素在不同屏幕尺寸下的显示顺序。默认值为0,数值越小越靠前,支持负数,仅作用于容器的直接子元素,不影响DOM结构。在Flex布局中,可设置order实现移动端内容优先加载,如将主要内容order设为0,导航设为2,桌面端通过媒体查询调整顺序;在Grid布局中,结合grid-area与order可实现复杂重排,如手机端按标题、图片、文本堆叠,大屏时重新定义区域并调整顺序。建议避免滥用负数或极端值,保持
-
filter+transition可实现平滑切换,但需确保函数形式一致(如grayscale(100%)↔grayscale(0%))、避免与transform共存、统一字符串格式并适配prefers-reduced-motion。
-
output标签必须绑定form元素才能正常更新;它本质是表单控件,依赖form关联和for属性指向输入源,无form或for则无法动态刷新,需配合oninput事件与JavaScript手动赋值value。
-
标记-清除算法通过可达性分析识别循环引用:从GCRoots出发遍历并标记所有可达对象,未被标记的不可达对象(即使彼此引用)在清除阶段被统一回收。
-
flex-wrap:wrap是实现自动换行的关键,不设则子元素强行挤在一行;需配合gap或space-around实现每行均匀分布,并通过flex-basis响应式调整列数,同时控制卡片宽高一致性。
-
SVG中<circle>与<ellipse>的核心差异在于坐标系理解:原点在左上角,cx/cy为绝对坐标,r或rx/ry需匹配svg宽高防溢出,且均不支持百分比单位。
-
Object.freeze仅浅冻结,嵌套对象仍可修改;deepFreeze需递归实现并严格在模块加载最前端执行,否则引用已缓存导致失效;冻结前须切断原型链、禁用代理与访问器。
-
<p>Less加减法必须单位一致,因编译期静态类型检查禁止跨单位运算;%与px混用如100%-20px会报错,需统一为无单位小数、换算为px或改用calc()字符串插值。</p>
-
应移除href属性并添加aria-disabled="true"、role="link"和tabindex="0",配合pointer-events:none与cursor:not-allowed,确保键盘与屏幕阅读器用户均可感知禁用状态。
-
跨组件锚点跳转需确保目标元素已真实挂载,React用useEffect+ref、Vue用onMounted/nextTick监听,优先用ref而非id查询,计算滚动位置时用getBoundingClientRect().top+scrollY,并处理头部遮挡及Safari兼容性问题。
-
@media(hover:hover)是最可靠的悬停检测方式,它严格判断系统是否稳定支持:hover伪类,而非仅检测输入设备精度;需用其包裹所有悬停样式与transition,并配合matchMedia在JS中同步状态。
-
纯CSS变量无法独立实现视差滚动,必须由JS注入--scroll-y等变量,再通过calc()配合transform实现;background-attachment:fixed在现代浏览器中受限严重,JS驱动方案最兼容。
-
绝对定位子元素不占位,完全脱离文档流,父容器计算尺寸时无视其存在;需为父元素设置position:relative等非static定位才能建立定位上下文,否则偏移参考祖先或body。
-
用class切换背景色应将颜色变量抽离到主题类名(如theme-light/theme-dark),通过CSS选择器层级或CSS变量统一控制,避免硬编码和!important;需同步设置HTML根元素class防FOUC,并显式重置表单控件及SVG等所有颜色上下文。