移动端的rem布局和VM布局

本文介绍了移动端UI适配的两种方法:rem布局和vw布局。通过使用amfe-flexible和postcss-pxtorem插件来实现rem布局,详细配置了postcss.config.js文件。此外,还讲解了vw布局的原理,通过postcss-px-to-viewport插件进行转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言:

在开发中我们会遇到ui给我们一套750px 的设计稿, 但是我们使用vant组件库开发的话,里面的都是写好了的,它里面的是375px

我们要做的是怎么把给的需求完成:

1.使用使用rem适配

  • 1安装 amfe-flexible插件

    • yarn add amfe-flexible

    • npm i amfe-flexible

  • 在main.js导入

    • import "amfe-flexible"

  • 安装postcss-pxtorem

    • yarn add postcss-pxtorem@5.0.0

  • 配制详情

创建postcss.config.js(加载css时使用)
module.exports={
    plugins:{
        rootValue:基准值(37.5),
        propList:哪些css需要转换,针对的css选择["*"]
    }
}

html 下font-size=屏幕宽度/10

设计稿:1080   723px用rem表示    723/108rem

const path = require('path')
module.exports = ({ file }) => {
  // 如果是vant的css需要转换,它的文件都是来自于node_modules/vant   
  // file.dirname:需要转换的文件路径
  const base = file.dirname.includes(path.join('node_modules', 'vant'))
    ? 37.5
    : 75
  return {
    plugins: {
      'postcss-pxtorem': {
        rootValue: base,
        propList: ['*']
      }
    }
  }
}

// module.exports={
//     plugins:{
//         // 二套:ui一套 750px   vant一套   375px
//         rootValue:基准值(37.5),  // 设计稿/10后的值
//         propList:哪些css需要转换,针对的css选择["*"]   // 哪些css需要转换
//     }
// }
// 2:下载与配制  postcss-pxtorem插件
const path = require("path");
module.exports = ({ file }) => {
  // 如果是vant的css需要转换,它的文件都是来自于node_modules/vant
  // file.dirname:需要转换的文件路径
  //   判断当前读取的文件路径是否包含vant,如果包含就是在解析vant的css,依赖设计稿是375宽度标准转换
  // 如果不包含说明是自己写的css,就依赖ui的设计稿宽度标准进行计算
  const base = file.dirname.includes(path.join("node_modules", "vant"))
    ? 37.5
    : 75;
  return {
    plugins: {
      "postcss-pxtorem": {
        rootValue: base,
        propList: ["*"],
      },
    },
  };
};

2.  vw适配

使用步骤如下

vw:100vw=== 屏幕的百分百 vh

  • 相对屏幕的百分比单位

  • 百分比是相对父级

实现过程:

  • 安装插件

    • yarn add postcss-px-to-viewport -D

  • 配制

    • 根目录下的postcss.config.js

    • const path = require("path");
      module.exports = ({ file }) => {
        const base = file.dirname.includes(path.join("node_modules", "vant"))
          ? 375
          : 750;
        return {
          plugins: {
            "postcss-px-to-viewport": {
              viewportWidth: base,
            },
          },
        };
      };

<think>好的,用户想了解REM在响应式布局中的用法,我需要根据提供的引用内容来组织回答。首先,要解释REM的基本概念,为什么它适合响应式布局,然后分步骤说明使用方法,可能还需要提到与em、px的区别,以及结合视口单位的优化方法。 首先,REM是相对于根元素(html)的字体大小,而em是相对于父元素,所以REM更统一,适合响应式设计。根据引用1,rem的标准统一,因此更适合响应式布局。而引用3提到浏览器默认1rem=16px,但通常会重置这个值以便计算。 接下来,使用方法部分需要分步骤。根据引用2,设置1rem=100px可能更方便计算,比如直接使用设计稿的px值除以100。然后,通过媒体查询调整不同屏幕下的根字体大小,或者结合vw单位让字体大小随视口变化,如引用2中的例子,设置html的font-size为(100vw/设计稿宽度)*基准值。 还要注意移动端的适配,可能需要设置viewport的meta标签,确保缩放正确。同时,可能提到使用Sass或Less来简化计算,比如引用2中的函数示例。 最后,对比remvw/vh,引用2引用3都提到了两者的结合使用,比如用vw设置根字体,再用rem进行布局,这样能更灵活响应不同屏幕。 需要确保回答结构清晰,步骤明确,可能还要包括注意事项优化技巧。同时生成相关问题,比如rem与em的区别、结合vw的方法、移动端适配等。</think>### REM 在响应式布局中的使用方法 #### 1. **REM 的基本原理** REM(Root EM)是 CSS 中的相对长度单位,**相对于根元素(即 `html` 标签)的 `font-size` 值**。例如: - 默认浏览器根元素字体大小为 `16px`,则 `1rem = 16px`[^3]; - 若设置 `html { font-size: 20px; }`,则 `1rem = 20px`。 这种特性使得 REM **标准统一**,避免了 EM 单位因父元素尺寸不同导致的混乱[^1]。 --- #### 2. **REM 实现响应式布局的步骤** ##### 步骤 1:重置根元素字体大小 通常会将 `1rem` 设置为方便计算的基准值(如 `100px`),避免默认 `16px` 带来的复杂换算: ```css html { font-size: 62.5%; /* 默认 16px × 62.5% = 10px → 1rem = 10px */ } ``` 或直接定义: ```css html { font-size: 100px; /* 1rem = 100px,设计稿尺寸可直接除以 100 转换为 rem */ } ``` ##### 步骤 2:通过媒体查询适配不同屏幕 根据不同屏幕宽度动态调整根字体大小: ```css @media (min-width: 375px) { /* 适用于 iPhone 12 等小屏 */ html { font-size: 104px; } } @media (min-width: 768px) { /* 平板 */ html { font-size: 110px; } } @media (min-width: 1200px) { /* 桌面端 */ html { font-size: 120px; } } ``` ##### 步骤 3:使用 REM 定义布局元素 将设计稿的像素值转换为 REM(例如设计稿宽度 750px,元素宽 150px → `1.5rem`): ```css .container { width: 7.5rem; /* 750px / 100 */ padding: 0.15rem; /* 15px / 100 */ } ``` --- #### 3. **优化技巧:REM + 视口单位(VM)** 结合 `vw`(视口宽度百分比)实现更灵活的响应式布局: ```css html { /* 假设设计稿宽度 750px → 100vw = 750px → 1vw = 7.5px */ font-size: calc(100vw / 7.5); /* 100vw / 7.5 = 13.333vw → 1rem = 100px */ } ``` 此方法让根字体随视口自动缩放,无需媒体查询[^2]。 --- #### 4. **注意事项** - **移动端适配**:需在 HTML 中添加 `<meta name="viewport" content="width=device-width, initial-scale=1.0">` 确保视口正确缩放; - **兼容性**:REM 兼容主流浏览器,但旧版本 IE 需降级处理; - **计算工具**:可使用 Sass/Less 函数简化 REM 转换: ```scss @function rem($px) { @return ($px / 100) * 1rem; } .box { width: rem(200); } /* 输出 width: 2rem; */ ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值