详解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 相关文章推荐
改进:论坛UBB代码自动插入方式
Dec 22 Javascript
PNGHandler-借助JS让PNG图在IE下实现透明(包括背景图)
Aug 31 Javascript
基于jquery的时间段实现代码
Aug 02 Javascript
缓动函数requestAnimationFrame 更好的实现浏览器经动画
Dec 07 Javascript
jquery单选框radio绑定click事件实现方法
Jan 14 Javascript
在Javascript中处理数组之toSource()方法的使用
Jun 09 Javascript
JS实现一个简单的日历
Feb 22 Javascript
用js实现before和after伪类的样式修改的示例代码
Sep 07 Javascript
AngularJS监听ng-repeat渲染完成的方法
Mar 20 Javascript
JS监听事件的叠加和移除功能
Nov 19 Javascript
layui复选框的全选与取消实现方法
Sep 02 Javascript
Vuex中的Mutations的具体使用方法
Jun 01 Javascript
小程序分享模块超级详解(推荐)
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
PHP实现多服务器session共享之NFS共享的方法
2007/03/16 PHP
php下连接ftp实现文件的上传、下载、删除文件实例代码
2010/06/03 PHP
PHP 设置MySQL连接字符集的方法
2011/01/02 PHP
php中的三元运算符使用说明
2011/07/03 PHP
Laravel 5+ .env环境配置文件详解
2020/04/06 PHP
Prototype Date对象 学习
2009/07/12 Javascript
js汉字排序问题 支持中英文混排,兼容各浏览器,包括CHROME
2011/12/20 Javascript
使用jquery解析XML的方法
2014/09/05 Javascript
JavaScript学习笔记之JS对象
2015/01/22 Javascript
jQuery使用removeClass方法删除元素指定Class的方法
2015/03/26 Javascript
react开发中如何使用require.ensure加载es6风格的组件
2017/05/09 Javascript
iscroll.js滚动加载实例详解
2017/07/18 Javascript
vue动态绑定组件子父组件多表单验证功能的实现代码
2018/05/14 Javascript
详解angular如何调用HTML字符串的方法
2018/06/30 Javascript
vue实现循环切换动画
2018/10/17 Javascript
jQuery实现表格的增、删、改操作示例
2019/01/27 jQuery
Vue监听滚动实现锚点定位(双向)示例
2019/11/13 Javascript
[03:09]2014DOTA2国际邀请赛 赛场上的美丽风景线 中国Coser也爱DOTA2
2014/07/20 DOTA
在Python中用keys()方法返回字典键的教程
2015/05/21 Python
windows下ipython的安装与使用详解
2016/10/20 Python
Python实现公历(阳历)转农历(阴历)的方法示例
2017/08/22 Python
python 字典中文key处理,读取,比较方法
2018/07/06 Python
django框架实现一次性上传多个文件功能示例【批量上传】
2019/06/19 Python
python多进程使用函数封装实例
2020/05/02 Python
python suds访问webservice服务实现
2020/06/26 Python
Python如何输出警告信息
2020/07/30 Python
维珍澳洲航空官网:Virgin Australia
2017/09/08 全球购物
linux面试题参考答案(6)
2014/08/29 面试题
EJB3推出JPA的原因
2013/10/16 面试题
交通法规咨询中心工作职责
2013/11/27 职场文书
个人素质的自我评价分享
2013/12/16 职场文书
语文课外活动总结
2014/08/27 职场文书
报考公务员诚信承诺书
2014/08/29 职场文书
浪漫婚礼主题活动策划方案
2014/09/15 职场文书
2014年话务员工作总结
2014/11/19 职场文书
工厂采购员岗位职责
2015/04/07 职场文书