移动端适配方案

rem+动态font-size

需要解决两个问题:
一,如何动态得到font-size
二,如何转化rem

1,获取动态font-size

可以使用js动态获取


 // 拿到html元素
      const htmlDom = document.documentElement;
      console.log("dom", htmlDom);
      // 改变的函数
      function serRemFontSize() {
        // 拿到屏幕的宽度
        const htmlWidth = htmlDom.clientWidth;
        console.log("dom宽度", htmlWidth);
        // 计算fontsize的大小
        const htmlFontSize = htmlWidth / 10;
        // fontsize赋值到html上
        htmlDom.style.fontSize = htmlFontSize + "px";
        console.log(htmlWidth);
      }
      // 第一次进来时主动调用一下
      serRemFontSize();
      // 实时监听屏幕尺寸改变的函数
      window.addEventListener("resize", serRemFontSize);
      // 监听页面跳转(前进或者后退),重新设置一下
      window.addEventListener("pageshow", function (e) {
        if (e.persisted) {
          serRemFontSize();
        }
      });

可以使用lib-flexible库

npm install -S amfe-flexible 

进行导入即可
import ‘amfe-flexible’

2,如何转化为rem

可以使用postcss-pxtorem插件
webpack打包时自动转换

npm install postcss-pxtorem --save-dev

在postcss.config.js中配置

module.exports = {
  plugins: [
    require('postcss-preset-env'),
    // 使用这个插件
    require('postcss-pxtorem')({
      rootValue: 37.5, // 设计稿宽度的1/10
      propList: ['*'], // 需要做转化处理的属性,如`hight``width``margin`等,`*`表示全部
      exclude: /node_modules/i // 忽略的文件
    })
  ]
};

可以在vscode使用px to rem插件进行配置
在这里插入图片描述
在Cssrem:Root Font Size设置 视口 % 10
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值