前端适配方案

前端适配了解

设备像素比

设备像素比 = 物理像素 / 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不同,还是会有影响。

相关推荐
candyTong19 小时前
一觉醒来,大模型就帮我排查完页面性能问题
前端·javascript·架构
魔术师Grace19 小时前
我给 AI 做了场入职培训
前端·程序员
玩嵌入式的菜鸡20 小时前
网页访问单片机设备---基于mqtt
前端·javascript·css
前端一小卒20 小时前
我用 Claude Code 的 Superpowers 技能链写了个服务,部署前差点把服务器搞炸
前端·javascript·后端
滑雪的企鹅.1 天前
HTML头部元信息避坑指南大纲
前端·html
一拳不是超人1 天前
老婆天天吵吵要买塔罗牌,我直接用 AI 2 小时写了个在线塔罗牌
前端·ai编程
excel1 天前
如何解决 Nuxt DevTools 中关于 unstorage 包的报错
前端
Rust研习社1 天前
使用 Axum 构建高性能异步 Web 服务
开发语言·前端·网络·后端·http·rust
C澒1 天前
AI 生码 - API2Code:接口智能匹配与 API 自动化生码全链路设计
前端·低代码·ai编程
浔川python社1 天前
HTML头部元信息避坑指南技术文章大纲
前端·html