详解vue.js移动端配置flexible.js及注意事项


Posted in Javascript onApril 10, 2019

前言

最近在用vue做移动端项目,网上找了一些移动端适配的方案,个人觉得手淘团队flexible.js还是比较容易上手,在这里做下总结。

主体

flexible.js适配方案采用rem布局,根据屏幕分辨率大小不同,调整根元素html的font-size,从而达到每个元素宽高自动变化,适配不同屏幕

1.安装lib-flexible.js

npm install lib-flexible --save

1.在项目入口文件main.js中引入lib-flexible

import 'lib-flexible/flexible'

通过要以上两步,就完成了在vue项目使用lib-flexible来解决移动端适配了。

lib-flexible会自动在html的head中添加一个meta name="viewport"的标签,同时会自动设置html的font-size为屏幕宽度除以10,也就是1rem等于html根节点的font-size。假如设计稿的宽度是750px,此时1rem应该等于75px。假如量的某个元素的宽度是150px,那么在css里面定义这个元素的宽度就是 width: 2rem

这里需要注意几点:

1.检查一下html文件的head中,如果有 meta name="viewport"标签,需要将他注释掉,因为如果有这个标签的话,lib-flexible就会默认使用这个标签。而我们要使用lib-flexible自己生成的 meta name="viewport"来达到高清适配的效果。

2.因为html的font-size是根据屏幕宽度除以10计算出来的,所以我们需要设置页面的最大宽度是10rem。

3.如果每次从设计稿量出来的尺寸都手动去计算一下rem,就会导致我们效率比较慢,还有可能会计算错误,所以我们可以使用px2rem-loader自动将css中的px转成rem

使用 webpack 的 px2rem-loader,自动将px转换为rem

1.安装px2rem-loader

npm install px2rem-loader --save-dev

1.配置px2rem-loader

首先找到 build/utils.js文件,在utils.js中添加如下配置

详解vue.js移动端配置flexible.js及注意事项

找到generateLoaders方法,在函数里如下配置

详解vue.js移动端配置flexible.js及注意事项

1.px2rem 用法

安装px2rem后,再使用px上有些不同,大家可以参考px2rem官方介绍,下面简单介绍一下。

•直接写px,编译后会直接转化成rem —- 除开下面两种情况,其他长度用这个

•在px后面添加/*no*/,不会转化px,会原样输出。 —- 一般border需用这个

•在px后面添加/*px*/,会根据dpr的不同,生成三套代码。—- 一般字体需用这个

下面是本人写的实例代码,可以参考

原始代码:

.box{
  width: 150px;
  font-size: 28px; /*px*/
  border: 1px solid #ddd; /*no*/
}

编译后生成代码:

.box{
  width: 2rem;
  border: 1px solid #ddd;
}
[data-dpr="1"] .selector {
  font-size: 14px;
}
[data-dpr="2"] .selector {
  font-size: 28px;
}
[data-dpr="3"] .selector {
  font-size: 42px;
}

这样基本配置就完成了,重启项目就可以使用lib-flexible+rem编写移动端页面了

后缀

交个朋友,可以一起进阶前端学习

找到我: GitHub

总结

以上所述是小编给大家介绍的vue.js移动端配置flexible.js及注意事项,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
JavaScript判断FileUpload控件上传文件类型
Sep 28 Javascript
理解 JavaScript Scoping & Hoisting(二)
Nov 18 Javascript
JS针对Array的各种操作汇总
Nov 29 Javascript
three.js快速入门【推荐】
Jan 21 Javascript
Angular.js去除页面中显示的空行方法示例
Mar 30 Javascript
详解Node项目部署到云服务器上
Jul 12 Javascript
Angular Material Icon使用详解
Nov 07 Javascript
微信小程序textarea层级过高(盖住其他元素)问题的解决办法
Mar 04 Javascript
深入理解JS异步编程-Promise
Jun 03 Javascript
JavaScript 处理树数据结构的方法示例
Jun 16 Javascript
js canvas实现五子棋小游戏
Jan 22 Javascript
vue 项目@change多个参数传值多个事件的操作
Jan 29 Vue.js
小程序分享模块超级详解(推荐)
Apr 10 #Javascript
关于JavaScript 数组你应该知道的事情(推荐)
Apr 10 #Javascript
Vue中computed、methods与watch的区别总结
Apr 10 #Javascript
JavaScript 性能提升之路(推荐)
Apr 10 #Javascript
详解vue-cli3 中跨域解决方案
Apr 10 #Javascript
js中数组常用方法总结(推荐)
Apr 09 #Javascript
JS隐藏号码中间4位代码实例
Apr 09 #Javascript
You might like
DISCUZ 论坛管理员密码忘记的解决方法
2009/05/14 PHP
php foreach正序倒序输出示例代码
2014/07/01 PHP
在SAE上搭建最新wordpress的方法
2014/12/21 PHP
php实现字符串翻转的方法
2015/03/27 PHP
php实现根据词频生成tag云的方法
2015/04/17 PHP
php基础设计模式大全(注册树模式、工厂模式、单列模式)
2015/08/31 PHP
PHP使用PDO访问oracle数据库的步骤详解
2017/09/29 PHP
Ubuntu中支持PHP5与PHP7双版本的简单实现
2018/08/19 PHP
Javascript 网页黑白效果实现代码(兼容IE/FF等)
2010/04/23 Javascript
js获取元素在浏览器中的绝对位置
2010/07/24 Javascript
jquery进行数组遍历如何跳出当前的each循环
2014/06/05 Javascript
JS获取浏览器语言动态加载JS文件示例代码
2014/10/31 Javascript
json+jQuery实现的无限级树形菜单效果代码
2015/08/27 Javascript
JS简单实现String转Date的方法
2016/03/02 Javascript
js css实现垂直方向自适应的三角提示菜单
2016/06/26 Javascript
JS只能输入正整数的简单实例
2016/10/07 Javascript
js如何判断是否在iframe中及防止网页被别站用iframe嵌套
2017/01/11 Javascript
Vue项目webpack打包部署到Tomcat刷新报404错误问题的解决方案
2018/05/15 Javascript
Postman动态获取返回值过程详解
2020/06/30 Javascript
Python base64编码解码实例
2015/06/21 Python
Python查询IP地址归属完整代码
2017/06/21 Python
使用Python处理Excel表格的简单方法
2018/06/07 Python
Python图像阈值化处理及算法比对实例解析
2020/06/19 Python
浅谈TensorFlow中读取图像数据的三种方式
2020/06/30 Python
python dict如何定义
2020/09/02 Python
CSS3实战第一波 让我们尽情的圆角吧
2010/08/27 HTML / CSS
CSS3 :not()选择器实现最后一行li去除某种css样式
2016/10/19 HTML / CSS
小学节能减排倡议书
2014/05/15 职场文书
驾驶员安全责任书范本
2014/07/24 职场文书
公司内部升职自荐信
2015/03/27 职场文书
自荐信模板大全
2015/03/27 职场文书
傲慢与偏见电影观后感
2015/06/10 职场文书
慰问信的写作格式及范文!
2019/06/24 职场文书
手把手教你用SpringBoot将文件打包成zip存放或导出
2021/06/11 Java/Android
SpringCloud Function SpEL注入漏洞分析及环境搭建
2022/04/08 Java/Android
Win Server2016远程桌面如何允许多用户同时登录
2022/06/10 Servers