-
z-index不生效的常见原因包括元素未定位、层叠上下文限制及z-index值相同。1.元素必须设置position为relative、absolute、fixed或sticky,否则z-index无效;2.不同层叠上下文中的元素,其堆叠顺序由各自上下文在父级中的层级决定,子级z-index再高也无法突破父级上下文;3.同一层叠上下文中z-index相同则后渲染的元素覆盖前者。排查时应检查元素是否定位、查看祖先元素是否创建了层叠上下文(如opacity小于1、transform、filter等属性),并逐
-
应复用同一Audio实例并在用户首次交互时预播放以解锁权限,用布尔变量控制开关状态,封装triggerCelebration函数解耦业务逻辑,按钮同步aria-pressed与audio.muted,iOS需预热播放或降级WebAudioAPI。
-
应使用background-imageCSS属性而非过时的bodybackground属性;正确写法包括指定url、background-size、background-repeat和background-position,避免简写导致意外重置,并通过开发者工具调试路径与加载问题。
-
JavaScript任务调度依赖事件循环机制,通过setTimeout、setInterval、requestAnimationFrame、WebWorkers及自定义队列等手段控制任务执行。事件循环管理宏任务(如setTimeout)与微任务(如Promise)的执行顺序,确保异步操作按规则运行。宏任务在每次循环中取一个执行,期间清空微任务队列,导致即使延迟为0的setTimeout也会滞后于同步代码和微任务。为实现并发控制,可构建TaskQueue类,限制同时运行的任务数量,避免资源过载。该类通过维护