JS实现css响应式布局方案

方案一: 纯css响应式布局

原理: 基于特定元素的宽度 而非视图 进行响应式布局
⚠️ 有兼容性问题

  • 观察的元素上
js 复制代码
    container-type :inline-size ; 
    container-name: drawer-container
  • 基于容器宽度的响应式布局定义
js 复制代码
 基于容器宽度(而非视口)的条件样式
  @container drawer-container (max-width: 780px) {
    .custom-drawer { 
       position: absolute; 
    } 
  }

方案二: css媒体查询的js实现

原理: 通过JS new ResizeObserver监听元素尺寸,动态切换css样式

1.你的场景:

  • 用户调整窗口大小 → 触发 ResizeObserver 回调,检测目标元素宽度变化。
  • 根据宽度阈值 → 动态修改 data-mode,切换 CSS 样式。

2. 关键问题分析:

  1. ResizeObserver 本身已经是异步的,浏览器会自动优化,避免强制同步布局(reflow)。
  2. requestAnimationFrame 的作用:确保 UI 更新与浏览器渲染帧同步,适合动画或高频视觉更新。
  3. throttle 的作用:控制回调执行频率,避免冗余计算。

2.1 需要使用 requestAnimationFrame

❌ 通常不需要,因为:

  • ResizeObserver 回调已经是在布局计算完成后触发,不会导致强制重排。
  • data-mode 的切换是轻量操作(修改 DOM 属性),不涉及复杂渲染或动画。

2.2 是否需要 throttle

✅ 推荐使用,但取决于 ResizeObserver 的触发频率:

  • 如果用户 快速拖拽窗口边缘ResizeObserver 可能高频触发(如每秒 100+ 次)。
  • 通过 throttle 限制检测频率(如 100ms),可减少不必要的计算。
js 复制代码
// 纯 throttle,100ms 检测一次(最佳平衡)
const handleResize = throttle((entries) => {
  const width = entries[0].contentRect.width;
  element.dataset.mode = width >= 768 ? "desktop" : "mobile";
}, 100, { leading: true, trailing: true });

const observer = new ResizeObserver(handleResize);
observer.observe(targetElement);
相关推荐
夏幻灵7 小时前
CSS三大特性:层叠、继承与优先级解析
前端·css
小杨同学呀呀呀呀7 小时前
Ant Design Vue <a-timeline>时间轴组件失效解决方案
前端·javascript·vue.js·typescript·anti-design-vue
华玥作者16 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_16 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠16 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
lang2015092816 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC17 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务18 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
嘿起屁儿整18 小时前
面试点(网络层面)
前端·网络
VT.馒头18 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript