【转载】阿里高清方案原理

强颜欢笑 提交于 2020-03-12 18:48:25

一、代码原理: 1.根据dpr(设备像素比,比如dpr=2时,表示1个CSS像素由2X2个物理像素点组成),动态设置html中font-szie的值 2.同时根据设备DPR调整页面的缩放值,进而达到高清效果。 二、源码

'use strict';
/**
 * @param {Boolean} [normal = false] - 默认开启页面压缩以使页面高清;  
 * @param {Number} [baseFontSize = 100] - 基础fontSize, 默认100px;
 * @param {Number} [fontscale = 1] - 有的业务希望能放大一定比例的字体;
 */
const win = window;
export default win.flex = (normal, baseFontSize, fontscale) => {
  const _baseFontSize = baseFontSize || 100;
  const _fontscale = fontscale || 1;

  const doc = win.document;
  const ua = navigator.userAgent;
  const matches = ua.match(/Android[\S\s]+AppleWebkit\/(\d{3})/i);
  const UCversion = ua.match(/U3\/((\d+|\.){5,})/i);
  const isUCHd = UCversion && parseInt(UCversion[1].split('.').join(''), 10) >= 80;
  const isIos = navigator.appVersion.match(/(iphone|ipad|ipod)/gi);
  let dpr = win.devicePixelRatio || 1;
  if (!isIos && !(matches && matches[1] > 534) && !isUCHd) {
    // 如果非iOS, 非Android4.3以上, 非UC内核, 就不执行高清, dpr设为1;
    dpr = 1;
  }
  const scale = normal ? 1 : 1 / dpr;

  let metaEl = doc.querySelector('meta[name="viewport"]');
  if (!metaEl) {
    metaEl = doc.createElement('meta');
    metaEl.setAttribute('name', 'viewport');
    doc.head.appendChild(metaEl);
  }
  metaEl.setAttribute('content', `width=device-width,user-scalable=no,initial-scale=${scale},maximum-scale=${scale},minimum-scale=${scale}`);
  doc.documentElement.style.fontSize = normal ? '50px' : `${_baseFontSize / 2 * dpr * _fontscale}px`;
};

  通过源码就可以很容易的看到,设置默认字体为100px,根据dpr 设置缩放比scale = 1/dpr,再更改font-size100/2*dprpx。

3、优点

  • 使用简单,放在head标签内即可。换算方便,直接根据设计稿(750px),尺寸进行开发(100px= 1rem
  • 自动设置高清缩放比,保证不同设备体验的一致性
  • 有效解决移动端真实1px问题(这里的1px 是设备屏幕上的物理像素)

4、只适合固定高宽的元素,可以配合百分比或flex布局开发。

5、其他,在webview里使用这个方案时,需要客户端把scalesPageToFit设为false,或者会不能对页面进行缩放

 

 

 

 

 

 

 

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!