移动端适配方案,基于postcss

简介: 【8月更文挑战第9天】

移动端适配配置项

方法1: postcss-px-viewport

1.安装 postcss-px-viewport 插件及其依赖:

npm install postcss-px-viewport postcss-viewport-units postcss-preset-env -D

其中,postcss-px-viewport 是主要的插件,postcss-viewport-units 和 postcss-preset-env 是其依赖,用于支持更多的 CSS 新特性和语法转换。

2.在项目根目录下创建 postcss.config.js 文件,配置 postcss-px-viewport 插件:

module.exports = {
plugins: {
"postcss-px-to-viewport": {
unitToConvert: "px", // 需要转换的单位
viewportWidth: 375, // 视口宽度,等同于设计稿宽度
unitPrecision: 5, // 精确到小数点后几位
/**

    * 将会被转换的css属性列表,
    * 设置为 * 表示全部,如:['*']
    * 在属性的前面或后面设置*,如:['*position*'],*position* 表示所有包含 position 的属性,如 background-position-y
    * 设置为 !xx 表示不匹配xx的那些属性,如:['!letter-spacing'] 表示除了letter-spacing 属性之外的其他属性
    * 还可以同时使用 ! 和 * ,如['!font*'] 表示除了font-size、 font-weight ...这些之外属性之外的其他属性名头部是‘font’的属性
    * */
  propList: ["*",],
  viewportUnit: "vw",    // 需要转换成为的单位
  fontViewportUnit: "vw",// 需要转换称为的字体单位
  /**
    * 需要忽略的选择器,即这些选择器对应的属性值不做单位转换
    * 设置为字符串,转换器在做转换时会忽略那些选择器中包含该字符串的选择器,如:['body']会匹配到 .body-class,也就意味着.body-class对应的样式设置不会被转换
    * 设置为正则表达式,在做转换前会先校验选择器是否匹配该正则,如果匹配,则不进行转换,如[/^body$/]会匹配到 body 但是不会匹配到 .body
    */
  selectorBlackList: ['sleepmode_item'],
  minPixelValue: 1,      // 最小的像素单位值
  mediaQuery: false,     // 是否转换媒体查询中设置的属性值
  replace: true,                 // 替换包含vw的规则,而不是添加回退
  /**
    * 忽略一些文件,如'node_modules'
    * 设置为正则表达式,将会忽略匹配该正则的所有文件
    * 如果设置为数组,那么该数组内的元素都必须是正则表达式
    */
  exclude: [],
  landscape: false,      // 是否自动加入 @media (orientation: landscape),其中的属性值是通过横屏宽度来转换的
  landscapeUnit: "vw",   // 横屏单位
  landscapeWidth: 1334,   // 横屏宽度
},

},
};
'
运行运行
方法2:postcss-pxtorem

  1. npm安装
    npm install postcss-pxtorem --save
    2.utils文件夹下(没有就新建一个),新建一个rem.js

代码如下:

function setRem() {
// 配置宽度为1920px时,1rem的值为:16px;
const screenWidth = 1280;
const scale = screenWidth / 16;
const htmlWidth = document.documentElement.clientWidth || document.body.clientWidth;
// 得到html的Dom元素
const htmlDom = document.getElementsByTagName('html')[0];
// 设置根元素字体大小
htmlDom.style.fontSize = htmlWidth / scale + 'px';
}
// 初始化
setRem();
// 改变窗口大小时重新设置 rem
window.onresize = function () {
setRem();
};

3.配置

代码:

postcss: {
postcssOptions: {
plugins: [
tailwindcss,
[
'postcss-pxtorem',
{
rootValue: 16, // 换算比例,结果为:设计稿元素尺寸/16,比如在css文件中设置元素宽width:320px,最终页面会换算成 320 / 16 = 20rem;还需要在rem.js中根据屏幕的实际宽度计算rem的动态值,即可算出20rem的值
unitPrecision: 5, // 保留rem小数点多少位
propList: [''], // 需要做转化处理的属性,如hightwidthletter-spacing等,``表示全部
// propBlackList: ['font-size'], //过滤掉不需要转换的属性
minPixelValue: 12, // px小于12的不会被转换,默认 0
selectorBlackList: ['el-', /^.ant/], // 忽略转换rem转换,正则匹配项(选择器),如:过滤点含有"el-"或以".ant"开头的选择器
exclude: /(\/|\)(MenuTool)(\/|\)/, // 忽略某些文件夹下的文件或特定文件,例如 'node_modules' 下的文件
},
],
],
},
},

相关文章
|
2月前
|
编解码 前端开发 JavaScript
前端移动端适配方案
【9月更文挑战第8天】前端移动端适配方案
92 0
|
3月前
|
资源调度 前端开发
|
3月前
|
移动开发 前端开发 开发者
|
3月前
|
Web App开发 前端开发
什么是移动端适配
【8月更文挑战第2天】
|
3月前
|
前端开发 JavaScript
移动端适配
【8月更文挑战第4天】
41 4
|
3月前
|
前端开发
移动端适配问题
【8月更文挑战第6天】
53 4
|
3月前
|
前端开发 小程序
移动端适配方案
【8月更文挑战第1天】
|
JavaScript
深入了解移动端适配的方案
深入了解移动端适配的方案
250 0
|
前端开发
【前端】移动端适配方案-rem
【前端】移动端适配方案-rem
146 0
|
编解码 前端开发 JavaScript
前端移动端优化和适配
前端移动端优化和适配
204 0