webpack的移动端适配方案小结


Posted in Javascript onJuly 25, 2021

在移动端开发的过程中,一个最常见的问题就是适配不同的屏幕宽度。目前比较常见的适配方案有rem和vw,它们都是css中的相对单位。

rem

W3C对rem的定义是 font-size of the root element,它是一个只相对于浏览器的根元素(HTML元素)的font-size的来确定的单位,也就是说对于不同宽度的机型,我们只需要计算出对应的根元素的字体大小,用同样的css代码可以实现等比适配。考虑最简单的情况:

html代码片段

//移动页面中不可少的meta,将设备屏幕的宽度设置成将文档宽度
<meta name="viewport" content="width=device-width, initial-scale=1,user-scalable=0">

js代码片段

//根据文档宽度计算根元素的字体大小,以文档宽度的1/10为例,如果屏幕宽度为375,那么根元素font-size就为37.5px
var w = document.documentElement.clientWidth;
document.documentElement.style.fontSize = w / 10 + 'px';

css代码片段

//此时如果在css中写
.div{
  width: 2rem;
}
//那么这个div的宽度就是75px,同理如果屏幕宽度为360,那么div就宽72px。
//日常开发中,比较常见的设计稿是750px,在设计稿中一个区域的高度为30px的话,
//在css中写成 height:0.4rem(30/75),就能完成等比缩放

而实际开发中,我们通常在webpack构建的时候使用插件来实现rem适配:postcss-pxtorem 和 lib-flexible。

安装:npm i postcss-pxtorem --D npm i amfe-flexible --S

在webpack.config.js中配置postcss-loader

module.exports = {
    entry: "./src/index.js",
    output: {
        path: path.join(__dirname,"/dist"),
        filename: "bundle.js"
    },
    module:{
        rules:[
            {
                test: /\.css$/,
                use:  ['style-loader','css-loader','postcss-loader']  //配置postcss-loader
            }
        ]
    },  
}

在项目根目录新建.postcssrc.js文件,在其中写入postcss-pxtorem插件配置

module.exports = {
  "plugins": {
    "postcss-pxtorem": {
        rootValue: 75,                   //750的设计稿
        propList: ['*']
     }
   }
}

在entry指定的入口js文件("./src/index.js")中引入lib-flexible

import 'amfe-flexible'

这样,就可以在css中直接写设计稿中的绝对像素值,比如一个div#test在750设计稿中的宽度为200px,就可以直接这样写,而不用换算了。

#test{
  width: 200px
}

vw

另外一种方案是使用vw:1% of viewport's width, 它是相对浏览器可视区域宽度的单位。

//移动页面中不可少的meta,将设备屏幕的宽度设置成将文档宽度
<meta name="viewport" content="width=device-width, initial-scale=1,user-scalable=0">

在移动端,如果配置了width = device-width,那么100vw就是屏幕宽度。

使用vw布局,就不需要再像rem那样,用js中去动态设置根元素的font-size,而是直接相对于屏幕宽度。比如750的设计稿中,一个div的宽度是200px,那么就可以写:width: 200 / 750 * 100 vw

而使用webpack,我们可以用 postcss-px-to-viewport 插件来实现:

安装:npm i postcss-px-to-viewport --D

如上rem那样在webpack.config.js配置 postcss-loader。
在项目根目录新建.postcssrc.js文件,在其中写入 postcss-px-to-viewport 插件配置

module.exports = {
  "plugins": {
    'postcss-px-to-viewport': {
        viewportWidth: 750                 //750的设计稿
     }
   }
}

这样也就可以在css中直接写设计稿中的绝对像素值,示例同上rem的示例。

适配第三方UI框架

有时候我们在移动端会使用其他组件库,引用像vant、mint-ui这样的第三方UI框架,因为第三方框架用的是px单位,基于375px的设计稿,如果我们的项目是750px的设计稿,就不能用同一个viewportWidth进行适配。

此时可以在.postcssrc.js中如下配置(以vw为例,rem也类似):

const path = require('path')
module.exports = ({file}) => {

  //如果使用vant UI框架
  const width = file.dirname.includes(path.join('node_modules', 'vant')) ? 375 : 750; 
  
  return {
    "plugins": {
      "postcss-px-to-viewport": {
        viewportWidth: width,
      }
    }
  }
}

结语

rem和vw都是常用的移动端适配解决方案。两者的区别,首先是在兼容性上,rem可以兼容更老的浏览器版本,参考caniuse网站 caniuse.com/ ;其次是rem需要通过js计算根元素的字体大小,vm是纯css实现。

到此这篇关于webpack的移动端适配方案小结的文章就介绍到这了,更多相关webpack 移动端适配内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
JS模拟多线程
Feb 07 Javascript
JQuery给网页更换皮肤的方法
May 30 Javascript
jQuery实现彩带延伸效果的网页加载条loading动画
Oct 29 Javascript
BootStrap创建响应式导航条实例代码
May 31 Javascript
mvc 、bootstrap 结合分布式图简单实现分页
Oct 10 Javascript
jQuery中checkbox反复调用attr('checked', true/false)只有第一次生效的解决方法
Nov 16 Javascript
JavaScript实现图像模糊化的方法实例
Jan 15 Javascript
JS Select下拉框(支持输入模糊查询)
Feb 04 Javascript
Vue项目引进ElementUI组件的方法
Nov 11 Javascript
Element Cascader 级联选择器的使用示例
Jul 27 Javascript
如何构建 vue-ssr 项目的方法步骤
Aug 04 Javascript
JavaScript实现瀑布流布局的3种方式
Dec 27 Javascript
Vue3.0 手写放大镜效果
ElementUI实现el-form表单重置功能按钮
vue项目多环境配置(.env)的实现
Node与Python 双向通信的实现代码
Jul 16 #Javascript
node.js如何自定义实现一个EventEmitter
Jul 16 #Javascript
node.js使用express-fileupload中间件实现文件上传
Jul 16 #Javascript
html5 录制mp3音频支持采样率和比特率设置
You might like
PHP 中文处理技巧
2010/04/25 PHP
php的chr和ord函数实现字符加减乘除运算实现代码
2011/12/05 PHP
zf框架db类的分页示例分享
2014/03/14 PHP
PHP中常用的字符串格式化函数总结
2014/11/19 PHP
php可生成缩略图的文件上传类实例
2014/12/17 PHP
深入php内核之php in array
2015/11/10 PHP
PHP上传Excel文件导入数据到MySQL数据库示例
2016/10/25 PHP
Jquery 获取表单text,areatext,radio,checkbox,select值的代码
2009/11/12 Javascript
js实时获取系统当前时间实例代码
2013/06/28 Javascript
jQuery的deferred对象详解
2014/11/12 Javascript
分享纯手写漂亮的表单验证
2015/11/19 Javascript
微信小程序实现蒙版弹窗效果
2018/11/01 Javascript
layui下拉框获取下拉值(select)的例子
2019/09/10 Javascript
JavaScript算法学习之冒泡排序和选择排序
2019/11/02 Javascript
vue双向绑定数据限制长度的方法
2019/11/04 Javascript
[53:36]Liquid vs VP Supermajor决赛 BO 第三场 6.10
2018/07/05 DOTA
python的类变量和成员变量用法实例教程
2014/08/25 Python
简单谈谈Python流程控制语句
2016/12/04 Python
python列表的增删改查实例代码
2018/01/30 Python
Tensorflow中使用tfrecord方式读取数据的方法
2018/06/19 Python
Python查找第n个子串的技巧分享
2018/06/27 Python
Python设计模式之桥接模式原理与用法实例分析
2019/01/10 Python
python中pip的使用和修改下载源的方法
2019/07/08 Python
使用Python matplotlib作图时,设置横纵坐标轴数值以百分比(%)显示
2020/05/16 Python
苏宁红孩子母婴商城:redbaby
2017/02/12 全球购物
优秀团员个人事迹材料
2014/01/29 职场文书
《恐龙》教学反思
2014/04/27 职场文书
竞选团支书演讲稿
2014/04/28 职场文书
后备干部推荐材料
2014/12/24 职场文书
档案工作个人总结
2015/03/03 职场文书
保研专家推荐信范文
2015/03/25 职场文书
革命电影观后感
2015/06/18 职场文书
2016年4月份红领巾广播稿
2015/12/21 职场文书
Pytorch 如何实现常用正则化
2021/05/27 Python
如何用Python搭建gRPC服务
2021/06/30 Python
Pygame Draw绘图函数的具体使用
2021/11/17 Python