Vue引入简单的rem

1.修改vue工程的index.html文件,参考代码为:

<!DOCTYPE html>
<html>
  <head>
  	<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0,minimum-scale=1.0, maximum-scale=1.0,user-scalable=no">
    <!-- 关闭手机号码识别功能-->
    <meta name="format-detection" content="telephone=no" />
    <title>出差申请</title>
  </head>
  <body>
    <div id="app"></div>
    <!-- built files will be auto injected -->
  </body>
  <script>
    fnResize()
    window.onresize = function () {
      fnResize()
    }
    function fnResize() {//根据显示宽度调节html的font-size尺寸
      var deviceWidth = document.documentElement.clientWidth || window.innerWidth
      if (deviceWidth >= 750) {
      deviceWidth = 750
    }
    if (deviceWidth <= 320) {
      deviceWidth = 320
    }
      document.documentElement.style.fontSize = Math.ceil(deviceWidth / 320 * 10) + 'px'
    }
</script>
</html>

2.然后,组件就可以使用rem样式了~

### 如何在 Vue 项目中通过 `postcss-pxtorem` 实现 rem 布局适配 #### 配置方案详解 为了实现基于 `postcss-pxtorem` 的 REM 布局适配,需要完成以下几个方面的配置: 1. **安装依赖** 在 Vue 项目中使用 `postcss-pxtorem` 插件前,需先安装必要的依赖包。可以通过 npm 或 yarn 安装这些工具。 ```bash npm install postcss-pxtorem amfe-flexible --save-dev ``` 2. **引入动态调整 HTML 字体大小的库** 使用 `amfe-flexible` 来自动计算并设置 `<html>` 元素的字体大小(即基准值)。这一步非常重要,因为它是整个布局的基础[^3]。 ```javascript // main.js 中引入 flexible 库 import 'amfe-flexible'; ``` 3. **PostCSS 配置文件编写** 下面展示了一个完整的 PostCSS 配置示例,适用于大多数 Vue 项目的场景。 #### 配置文件:`postcss.config.js` ```javascript module.exports = { plugins: { autoprefixer: {}, // 添加浏览器兼容性前缀 'postcss-pxtorem': { // 将 px 转换为 rem 单位的核心插件 rootValue: 37.5, // 设计稿宽度为 375px,则根节点 font-size 设置为 37.5px unitPrecision: 5, // 转换后的单位精度,默认保留到小数点后五位 propList: ['*'], // 所有属性都将被转换成 rem 单位 selectorBlackList: [], // 黑名单中的 CSS 类名不会被处理 replace: true, // 替换原有的样式声明 mediaQuery: false, // 是否允许媒体查询中的单位也进行转换 minPixelValue: 2 // 默认小于该像素值的不转换 } } }; ``` 上述配置说明如下: - `rootValue`: 表示设计稿每份的比例基数,如果设计稿宽为 375px 则取值为 37.5;如果是 750px 取值则应设为 75[^2]。 - `propList`: 指定哪些 CSS 属性会被转换单位,这里采用通配符 `'*'` 表示全部属性都会参与转换。 4. **实际应用案例** 当上述配置完成后,在开发过程中只需按照常规方式书写 PX 样式即可,最终会由 PostCSS 自动生成对应的 REM 值。 ```css /* 输入 */ .example-class { width: 187.5px; height: 93.75px; margin-top: 37.5px; } /* 输出 (经过 postcss-pxtorem 处理之后的结果) */ .example-class { width: 5rem; /* 187.5 / 37.5 */ height: 2.5rem; /* 93.75 / 37.5 */ margin-top: 1rem;/* 37.5 / 37.5 */ } ``` #### 注意事项 尽管此方法简单高效,但在具体实施时仍需要注意一些细节问题: - 如果页面中有部分区域不需要跟随整体缩放逻辑,可通过 `selectorBlackList` 参数将其排除在外[^4]。 - 对于图片资源或其他固定尺寸的内容,建议单独设定规则以免影响视觉效果一致性。 ```python print("REM Layout Adaptation Configured Successfully!") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值