前端适配方案

前端适配了解

设备像素比

设备像素比 = 物理像素 / css逻辑像素

Dpr 是 1 时,代表用一个物理像素渲染一个css像素。

Dpr 是 2 时,代表用四个物理像素渲染一个css像素,水平和垂直方向各用两个物理像素渲染一个逻辑像素。

因此同等分辨率的情况下,dpr更高显示效果越细腻。

分辨率

分辨率 = 水平物理像素 * 垂直物理像素

css逻辑分辨率 = 物理分辨率 / 设备像素比

同等分辨率的情况,设备像素比越高,css逻辑分辨率越低,相同的css像素占据更多物理空间,视觉效果偏大。

成本低就是用meta标签,当然也不是所有场景都适用。

移动端适配方案vw配合rem

先将页面整屏切割成10份,多少份都可以,以10份为例

理念:元素大小是相对屏幕宽度的,元素占了屏幕多少份。

代码方案:根元素设置fontSize,用postcss-pxtorem进行转换

优点:开发影响小,适用于现代浏览器,且不受dpr影响。

缺点:产品如果不想要等比缩放,那么该方案不适用。

方案衍生

  • 根元素计算fontSize配合插件转rem,但计算需考虑dpr影响,适用于需兼容低版本浏览器。
  • 方案根本其实就是将元素计算成屏幕占比,那么也可以直接配合插件直接转vw实现适配方案。

百分比适配方案

每个元素依据包含块的尺寸进行百分比样式设置。

成本比较高,需要对不同css属性百分比属性值熟悉。

scale缩放

使用页面需整体缩放且保持一定宽高比,比如视频和图片。

js 复制代码
  const objectFitContainerStyle = useMemo(() => {
    const { width, height } = containerSize;
    return {
      transform: `scale(${width / height > 16 / 9 ? height / 1080 : width / 1920})`,
    };
  }, [containerSize]);

媒体查询

用媒体查询适配不同分辨率。

但解决不了dpr的问题,同等物理分辨率但dpr不同,还是会有影响。

相关推荐
We་ct2 小时前
LeetCode 226. 翻转二叉树:两种解法(递归+迭代)详解
前端·算法·leetcode·链表·typescript
叫我一声阿雷吧2 小时前
JS实现无限滚动加载列表|适配多端+性能优化【附完整可复用源码】
开发语言·javascript·性能优化
哆啦A梦15882 小时前
Vue3魔法手册 作者 张天禹 013_pinia
前端·vue.js·typescript
哆啦A梦15882 小时前
Vue3魔法手册 作者 张天禹 014_组件通信
前端·vue.js·typescript
木斯佳2 小时前
前端八股文面经大全:有赞前端一面二面HR面(2026-1-13)·面经深度解析
前端·状态模式
码云数智-园园2 小时前
Vue 3 + TypeScript 企业级项目架构实战:从0到1打造可维护的前端工程体系
前端·vue.js·typescript
CappuccinoRose2 小时前
CSS 语法学习文档(十五)
前端·学习·重构·渲染·浏览器
Marshall1513 小时前
DC-SDK 实战指南:基于 Cesium 的三维数字孪生大屏开发 前言 在当今数字孪生、智慧城市等领域的开发中,三维地图可视化已经成为核心需求。
前端
少云清3 小时前
【UI自动化测试】5_web自动化测试 _元素操作和元素信息获取
前端·web自动化测试