基于vue-cli配置手淘的lib-flexible + rem,实现移动端自适应
时间:2022-03-12 19:19
转自:https://segmentfault.com/a/1190000011883121
没接触过flexible的建议先看看这样你才会知道长度为什么用rem,而字体要用px
-
安装flexible
关于importLoaders
:如若有疑问,请参考
2017.12.8更新说明:是否需要配置importLoaders
,可参考最底部的说明。
-
px2rem 用法
安装px2rem后,再使用px上有些不同,大家可以参考官方介绍,下面简单介绍一下。
直接写px,编译后会直接转化成rem ---- 除开下面两种情况,其他长度用这个
在px后面添加/*no*/
,不会转化px,会原样输出。 --- 一般border需用这个
在px后面添加/*px*/
,会根据dpr的不同,生成三套代码。---- 一般字体需用这个
示例代码
编译前(自己写的代码)
.selector {
width: 150px;
height: 64px; /*px*/
font-size: 28px; /*px*/
border: 1px solid #ddd; /*no*/
}
编译后(打包后的代码)
.selector {
width: 2rem;
border: 1px solid #ddd;
}
[data-dpr="1"] .selector {
height: 32px;
font-size: 14px;
}
[data-dpr="2"] .selector {
height: 64px;
font-size: 28px;
}
[data-dpr="3"] .selector {
height: 96px;
font-size: 42px;
}
-
重启项目,就可以愉快的用设计稿上的px了。
注意:坑
- 不能在index.html的头部加 name 为 viewport 的 meta 标签,flexible会自动为我们添加!
更新:对外部引入css,px2rem能不能转换rem问题
2017.12.8更新:在实际运用中发现对于外部引入的css文件,有时候px2rem能正常转换,有时候又不能转换,到底是什么原因呢?试验了三种不同的css引入情况,发现第一种能正常转换,二三不能正常转换,至于原因,由于才疏学浅,还是不懂,求大神解答三种引入方式的区别。
如果明白了这些方法,就没必要再配置cssLoader
的importLoaders
了,因为下面的方法更容易控制外部引入的css是否需要转rem,而更改importLoaders
就控制不了了,它会强制转换。
<style src=‘../assets/style.css‘>
/* px2rem能正常转换 */
</style>
<style>
/* px2rem不能正常转换 */
@import ‘../assets/style.css‘;
</style>
<style>
/* px2rem不能正常转换 */
@import url(‘../assets/style.css‘);
</style>
相关推荐
- Android系统编程入门系列之界面Activity交互响应
- 新型横向移动工具原理分析、代码分析、优缺点以及检测方案
- uni-app滚动视图容器(scroll-view)之监听上拉事件
- uniapp h5,app两端复制文本
- Android系统编程入门系列之界面Activity响应丝滑的传统动画
- 【Azure 应用服务】App Service 配置 Application Settings 访问Storage Account得到 could not be resolved: '*.file.core.windows.net'的报错。没有解析成对应中国区 Storage Account地址 *.file.core.chinacloudapi.cn
- 诺基亚短信生成!太好玩了
- iOS 跳转App Store进行评分
- 开发一个即时通讯App
- 关闭苹果IOS app自动更新
电脑软件
本类排行
- 1关闭苹果IOS app自动更新
- 2iOS 跳转App Store进行评分
- 3诺基亚短信生成!太好玩了
- 4Android系统编程入门系列之界面Activity响应丝滑的传统动画
- 5uniapp h5,app两端复制文本
- 6uni-app滚动视图容器(scroll-view)之监听上拉事件
- 7新型横向移动工具原理分析、代码分析、优缺点以及检测方案
- 8Android系统编程入门系列之界面Activity交互响应
- 9开发一个即时通讯App
- 10【Azure 应用服务】App Service 配置 Application Settings 访问Storage Account得到 could not be resolved: '*.file.core.windows.net'的报错。没有解析成对应中国区 Storage Account地址 *.file.core.chinacloudapi.cn