详解vue中移动端自适应方案


Posted in Javascript onMay 05, 2019

方案1:

直接引入js  (自己 写的动态改变fontsize的js)

function htRem() {
	  var ww = document.documentElement.clientWidth;
	  if (ww > 750) {
	    ww = 750;
	  }
	  document.documentElement.style.fontSize = ww / 7.5 + "px";
	}
	htRem();
	window.onresize = function() {
	  htRem();
	};

在main.js中import引入即可
方案二:手淘的 lib-flexible + rem

配置 flexible

安装 lib-flexible

在命令行中运行如下安装:

npm i lib-flexible --save

引入 lib-flexible

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

// main.js
import 'lib-flexible'

添加 meta 标签

在项目根目录的 index.html 中添加如下 meta

<meta name="viewport" content="width=device-width, initial-scale=1.0">

px 转 rem

实际开发中,我们通过设计稿得到的值单位是 px,所以要将 px 转换成 rem 再写进样式中。
将 px 转换成 rem 我们将使用 px2rem 这个工具,它有 webpack 的 loader:px2rem-loader

安装 px2rem-loader

在命令行中运行如下安装:

npm i px2rem-loade --save-dev

配置 px2rem-loade

在 vue-cli 生成的 webpack 配置中,vue-loader 的 options 和其他样式文件 loader 最终是都是由 build/utils.js 里的一个方法生成的。

我们只需在 cssLoader 后再加上一个 px2remLoader 即可,px2rem-loader 的 remUnit 选项意思是 1rem=多少像素,结合 lib-flexible 的方案,我们将 px2remLoader 的 options.remUnit 设置成设计稿宽度的 1/10,这里我们假设设计稿宽为 750px。

// utils.js
var cssLoader = {
loader: 'css-loader',
options: {
minimize: process.env.NODE_ENV === 'production',
sourceMap: options.sourceMap
}
}
var px2remLoader = {
loader: 'px2rem-loader',
options: {
remUnit: 75
}
}
// ...

并放进 loaders 数组中

// utils.js
function generateLoaders(loader, loaderOptions) {
var loaders = [cssLoader, px2remLoader]
// ...

修改配置后需要重启,然后我们在组件中写单位直接写 px,设计稿量多少就可以写多少了,舒服多了。

以上所述是小编给大家介绍的vue移动端自适应详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery随意添加移除html的实现代码
Jun 21 Javascript
javascript判断是否按回车键并解决浏览器之间的差异
May 13 Javascript
利用a标签自动解析URL分析网址实例
Oct 20 Javascript
jquery插件jquery.beforeafter.js实现左右拖拽分隔条对比图片的方法
Aug 07 Javascript
分享有关jQuery中animate、slide、fade等动画的连续触发、滞后反复执行的bug
Jan 10 Javascript
JS中mouseup事件丢失的原因与解决办法
Jun 14 Javascript
input框中自动展示当前日期yyyy/mm/dd的实现方法
Jul 06 Javascript
在Create React App中使用CSS Modules的方法示例
Jan 15 Javascript
JS实现字体背景跑马灯
Jan 06 Javascript
vue子组件改变父组件传递的prop值通过sync实现数据双向绑定(DEMO)
Feb 01 Javascript
vue开发中遇到的问题总结
Apr 07 Javascript
JavaScript实现显示和隐藏图片
Apr 29 Javascript
解决ie11 SCRIPT5011:不能执行已释放Script的代码问题
May 05 #Javascript
彻底揭秘keep-alive原理(小结)
May 05 #Javascript
angular4+百分比进度显示插件用法示例
May 05 #Javascript
vuejs数据超出单行显示更多,点击展开剩余数据实例
May 05 #Javascript
Vue+Express实现登录状态权限验证的示例代码
May 05 #Javascript
微信小程序实现发送模板消息功能示例【通过openid推送消息给用户】
May 05 #Javascript
浅谈Node 异步IO和事件循环
May 05 #Javascript
You might like
PHP下打开phpMyAdmin出现403错误的问题解决方法
2013/05/23 PHP
Javascript 错误处理的几种方法
2009/06/13 Javascript
使用js简单实现了tree树菜单
2013/11/20 Javascript
一个字符串反转函数可实现字符串倒序
2014/09/15 Javascript
Node.js 异步编程之 Callback介绍(一)
2015/03/30 Javascript
JS动态改变表格边框宽度的方法
2015/03/31 Javascript
jquery实现从数组移除指定的值
2015/06/24 Javascript
jquery实现超简洁的TAB选项卡效果代码
2015/08/28 Javascript
用AngularJS的指令实现tabs切换效果
2016/08/31 Javascript
jquery利用json实现页面之间传值的实例解析
2016/12/12 Javascript
JS前端开发判断是否是手机端并跳转操作(小结)
2017/02/05 Javascript
jQuery事件详解
2017/02/23 Javascript
jQuery给表格添加分页效果
2017/03/02 Javascript
基于Vue2.0+ElementUI实现表格翻页功能
2017/10/23 Javascript
javascript显示动态时间的方法汇总
2018/07/06 Javascript
koa2服务端使用jwt进行鉴权及路由权限分发的流程分析
2019/07/22 Javascript
如何在JavaScript中正确处理变量
2020/12/25 Javascript
[07:12]2014DOTA2西雅图国际邀请赛 黑马Liquid专题采访
2014/07/12 DOTA
Python实现求最大公约数及判断素数的方法
2015/05/26 Python
Python命名空间的本质和加载顺序
2018/12/17 Python
Python中常用的内置方法
2019/01/28 Python
python3正则提取字符串里的中文实例
2019/01/31 Python
python实现提取str字符串/json中多级目录下的某个值
2020/02/27 Python
Selenium常见异常解析及解决方案示范
2020/04/10 Python
pandas分批读取大数据集教程
2020/06/06 Python
Python调用OpenCV实现图像平滑代码实例
2020/06/19 Python
详解pandas赋值失败问题解决
2020/11/29 Python
澳大利亚最大的女装零售商:Millers
2017/09/10 全球购物
如何用JQuery进行表单验证
2013/05/29 面试题
管理部部长岗位职责
2013/12/05 职场文书
贺卡寄语大全
2014/04/11 职场文书
2014年幼儿园班级工作总结
2014/12/17 职场文书
2015年安全月活动总结
2015/03/26 职场文书
初一年级组工作总结
2015/08/12 职场文书
高中地理教学反思
2016/02/19 职场文书
Python学习开发之图形用户界面详解
2021/08/23 Python