-
应移除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等所有颜色上下文。
-
懒加载与动态导入本质是按需加载技术,核心为动态import()语法,支持运行时调用、变量路径和构建工具代码分割,用于路由、交互、视口等场景,需结合实际性能权衡使用。
-
不能直接读取富文本或图片二进制数据,navigator.clipboard.read()仅能读取指定MIME类型的Blob,但支持极有限:仅Chromium稳定支持图片(image/png等),text/html常被忽略或降级为纯文本;需用户手势触发、HTTPS环境,且Firefox、Safari不支持read()。
-
JavaScript迭代器是支持for...of等语法的协议机制,核心为返回{value,done}对象的next()方法;需同时满足可迭代协议(含[Symbol.iterator]方法)和迭代器协议(next方法返回指定结构对象)。
-
Flex从模型层面绕开float缺陷,容器真实感知子项并统一调度空间;float靠推挤且垂直失控,flex用justify-content和align-items统一控制对齐,原生支持响应式、等高列、顺序切换与gap间隙管理。
-
CSS的overflow属性用于控制容器内容溢出时的显示方式,包括hidden(裁剪)、auto(按需滚动)和scroll(强制滚动条),需配合尺寸设置与盒模型使用。
-
transition-timing-function用于控制CSS过渡速度变化,支持ease、linear、ease-in、ease-out、ease-in-out等预设函数,也可通过cubic-bezier()自定义贝塞尔曲线实现弹性或回弹效果,配合steps()可创建分步动画,如数字翻牌,合理使用可提升界面动效的自然度与交互质感。
-
应使用width+var(--nav-width)替代flex-basis,因CSS规范限制flex-basis不支持直接解析CSS变量;侧边栏设width:var(--nav-width,240px);flex:00auto;,主内容区设flex:1;。
-
CSS-in-JS不能在纯HTML中直接使用,因其依赖JavaScript运行时、模块系统及专用库(如styled-components)动态生成并注入样式,而原生HTML无此执行环境。
-
函数是JavaScript的基石和一等公民,可赋值、传参、返回、动态创建;所有异步与事件处理必须依赖函数;函数声明与表达式在提升、this绑定、调试信息上差异显著;闭包会保留外层变量导致内存驻留。