rem适配三种常用封装

作者: 禾小沐的技术与生活 | 来源:发表于2018-06-20 16:31 被阅读45次

之前写了一篇关于rem适配的文章,但是没有给出具体的封装,这里给出常用的三种方法.

rem1.js

第一种方法考虑了m端屏幕旋转的问题.对兼容性做出了一定的处理,具体看代码.

export function rem (doc, win) {
  let docEl = doc.documentElement;
  //考虑以及兼容了 屏幕旋转的事件
  let resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize';
  let recalc = function () {
            var clientWidth = docEl.clientWidth;
            if (!clientWidth) return;
            if (clientWidth >= 750) {
                 docEl.style.fontSize = '100px';
            } else {
                 docEl.style.fontSize = 100 * (clientWidth / 750) + 'px';
            }
      };

   if (!doc.addEventListener) return;
    win.addEventListener(resizeEvt, recalc, false);                         // 屏幕大小以及旋转变化自适应
    doc.addEventListener('DOMContentLoaded', recalc, false);     // 页面初次打开自适应
    recalc();
};

rem2.js

采用html标签的offsetWidth长度计算,

export function rem() {
  var fz = document.querySelector('html').offsetWidth / 7.5; //设计图 750 1rem=100px
  document.querySelector('html').style.fontSize =
    fz <= 100 ? fz + 'px' : '100px';
  window.onresize = function() {
    rem();
  };
};

rem3.js

采用window.innerWidth计算,设置了body fontSize防止字体继承,使页面字体过大.

export function rem() {
  document.documentElement.style.fontSize = window.innerWidth / 7.5 + 'px'; //1rem = 100px
  document.body.style.fontSize = '14px';// 在body上将字体还原大小,避免页面无样式字体超大
}

相关文章

  • rem适配三种常用封装

    之前写了一篇关于rem适配的文章,但是没有给出具体的封装,这里给出常用的三种方法. rem1.js 第一种方法考虑...

  • rem适配,vw适配

    一.rem适配 之前对rem的适配仅仅停留在使用的阶段,近期需要进行源码封装,于是乎对原理进行了探寻,其实就是数学...

  • vuecli3 vant rem 移动端框架方案

    描述 基于vue-cli3.0+webpack 4+vant ui + sass+ rem适配方案+axios封装...

  • 前端开发常用单位px,rem,em区别

    首先,px是最常用的单位,一般用于PC端开发,而rem能等比例适配所有屏幕,通常用于响应手机端。 rem是相对于根...

  • 适配及响应式

    1.三种方法 rem、百分比、媒体查询(rem布局一般用于移动端适配;百分比+媒体查询用于移动端适配和PC响应式都...

  • vue3.0 高仿饿了么项目(项目初始化)

    对于移动端适配的理解 常用rem作为适配方案 对于flex的理解 样式当前有效 项目初始化 移动端屏幕禁止缩放 ...

  • 适配rem

    PPI 计算 适配rem

  • 用SnapKit适配tableviewcell的自适应高度

    iOS的时候经常用masnory进行适配,SnapKit是一个用Swift封装的autolayout自动适配的库,...

  • 解决vue移动端适配问题

    1,先看看网上关于移动端适配讲解 再聊移动端页面适配,rem和vw适配方案! 基础点:rem相对根节点 字体的大小...

  • vue移动端入门小项目

    1.始化项目 2.配置rem适配方式 && 封装http请求方法 在src目录下新建tools文件夹,放置js脚本...

网友评论

    本文标题:rem适配三种常用封装

    本文链接:https://www.haomeiwen.com/subject/ucyxyftx.html