前端适配方案

前端适配了解

设备像素比

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

相关推荐
禅思院33 分钟前
大列表性能优化 · 工程实战·四
开发语言·前端·性能优化·前端框架·php·异步加载
rising start34 分钟前
五、Vue3 ref 用法 + Props 完整指南
前端·javascript·vue.js
web打印社区34 分钟前
前端html转换pdf并静默打印pdf最佳实现路径
前端·javascript·vue.js·electron·html
Curvatureflight44 分钟前
浏览器音频采集实践:麦克风权限、降噪、回声消除与 PCM 转换
前端·javascript·音视频·信息与通信·web·pcm
Dontla1 小时前
HTML实体转义(HTML Entity Escaping)介绍
前端·html
咸鱼翻身小阿橙1 小时前
高斯模糊降噪/磨皮算法降噪图像
前端·opencv·算法·webpack·c#
ct9781 小时前
ES6 新特性
前端·vue.js·性能优化
KaMeidebaby1 小时前
卡梅德生物技术快报|抗原如何自己检测?FAdV-4 重组抗原制备与 ELISA 体系技术调试指南
前端·人工智能·物联网·算法·百度
一拳不是超人1 小时前
AI 辅助研发时代,如何用“规范 Skill”缩短测试周期
前端·人工智能·代码规范
夜郎king3 小时前
湖南高考天气查询:基于 HTML5 与百度天气 API 实现页面展示
前端·html5·百度天气实践·天气信息可视化