vue做移动端适配最佳解决方案(亲测有效)


Posted in Javascript onSeptember 04, 2018

vw 解决方案

1. 安装并配置PostCss插件

npm i postcss-aspect-ratio-mini postcss-px-to-viewport postcss-write-svg postcss-cssnext postcss-viewport-units cssnano --S

2. 对 PostCss 进行配置

找到在根目录中的.postcssrc.js,对PostCSS插件进行配置

module.exports = {
 "plugins": {
  "postcss-import": {},
  "postcss-url": {},
  // to edit target browsers: use "browserslist" field in package.json
  "postcss-write-svg": {
   uft8: false
  },
  "postcss-cssnext": {},
  "postcss-px-to-viewport": {
   viewportWidth: 750, // 视窗的宽度,对应的是我们设计稿的宽度,一般是750
   viewportHeight: 1334, // 视窗的高度,根据750设备的宽度来指定,一般指定1334,也可以不配置
   unitPrecision: 3, // 指定`px`转换为视窗单位值的小数位数(很多时候无法整除)
   viewportUnit: 'vw', // 指定需要转换成的视窗单位,建议使用vw
   selectorBlackList: ['.ignore', '.hairlines'], // 指定不转换为视窗单位的类,可以自定义,可以无限添加,建议定义一至两个通用的类名
   minPixelValue: 1, // 小于或等于`1px`不转换为视窗单位,你也可以设置为你想要的值
   mediaQuery: false // 允许在媒体查询中转换`px`
  },
  "postcss-viewport-units": {},
  "cssnano": {
   preset: "advanced",
   autoprefixer: false, // 和cssnext同样具有autoprefixer,保留一个
   "postcss-zindex": false
  }
 }
}

3. 引入viewport-units-buggyfill解决兼容问题

在 index.html 中引入js

<script src="//g.alicdn.com/fdilab/lib3rd/viewport-units-buggyfill/0.6.2/??viewport-units-buggyfill.hacks.min.js,viewport-units-buggyfill.min.js"></script>
<script>
 window.onload = function () { 
  window.viewportUnitsBuggyfill.init({ hacks: window.viewportUnitsBuggyfillHacks });
 }
</script>

最近在做商城的项目,发现有赞的ui非常适合,但有一个问题是有赞的ui用的单位是px,做不了移动端的适配,官网的提供的vw适配方案发现不可行,最后还是决定rem来做适配,上网搜了一下,发现了一套可用方案,亲测有效哦

它的原理是借助px2rem 插件方便的将px单位转为了rem

具体步骤:

安装

npm install px2rem-loader lib-flexible --save

在main.js中引入lib-flexible

import 'lib-flexible/flexible.js'

在build下的 utils.js中,找到generateLoaders 方法,添加以下代码

const px2remLoader = {
  loader: 'px2rem-loader',
  options: {
  remUnit: 37.5
  }
}
 
function generateLoaders (loader, loaderOptions) {
  const loaders = [cssLoader, px2remLoader]
  if (loader) {
    loaders.push({
    loader: loader + '-loader',
    options: Object.assign({}, loaderOptions, {
    sourceMap: options.sourceMap
    })
  })
}

重启项目,会发现自己设置的px被转为rem 了

但是有一定的局限性

以上实现转换适用于:

(1)组件中编写的<style></style>下的css

(2)从index.js或者main.js中import ‘../../static/css/reset.css'引入css

(3)在组件的<script type=”text/ecmascript-6″> import ‘../../static/css/reset.css'</script>中引入css

另外的情况不适用:

(1)组件<style></style>中@import “../../static/css/reset.css (可考虑上面(2)、(3)的形式引入)

(2)外部样式:<link rel=”stylesheet” href=”static/css/reset.css”>

(3)元素内部样式:style=”height: 417px; width: 550px;”

另外我要补充的是:在做移动端适配的时候我们不建议给字体也设置rem的单位,针对这种情况,我为字体适配的解决方案是使用媒体查询,文件以组件<style></style>中@import “../../static/css/reset.css形式引入,可完美解决移动端适配问题

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery.Validate 使用笔记(jQuery Validation范例 )
Jun 25 Javascript
Google 静态地图API实现代码
Nov 19 Javascript
Javascript实现飞动广告效果的方法
May 25 Javascript
js判断radiobuttonlist的选中值显示/隐藏其它模块的实现方法
Aug 25 Javascript
JavaScript正则表达式简单实用实例
Jun 23 Javascript
jQuery实现点击关注和取消功能
Jul 03 jQuery
jQuery选择器之子元素选择器详解
Sep 18 jQuery
浅谈React中组件间抽象
Jan 27 Javascript
JavaScript实现动态添加、移除元素或属性的方法分析
Jan 03 Javascript
手把手教你 CKEDITOR 4 实现Dialog 内嵌 IFrame操作详解
Jun 18 Javascript
详解js中的原型,原型对象,原型链
Jul 16 Javascript
jQuery treeview树形结构应用
Mar 24 jQuery
基于element-ui的rules中正则表达式
Sep 04 #Javascript
微信小程序的部署方法步骤
Sep 04 #Javascript
vue2中使用sass并配置全局的sass样式变量的方法
Sep 04 #Javascript
Element UI 自定义正则表达式验证方法
Sep 04 #Javascript
在vue项目中引入高德地图及其UI组件的方法
Sep 04 #Javascript
使用validate.js实现表单数据提交前的验证方法
Sep 04 #Javascript
快速解决vue-cli在ie9+中无效的问题
Sep 04 #Javascript
You might like
php中print(),print_r(),echo()的区别详解
2014/12/01 PHP
php+curl 发送图片处理代码分享
2015/07/09 PHP
windows下apache搭建php开发环境
2015/08/27 PHP
详解WordPress中添加友情链接的方法
2016/05/21 PHP
jQuery 核心函数以及jQuery对象
2010/03/23 Javascript
JS、jquery实现几分钟前、几小时前、几天前等时间差显示效果的代码实例分享
2014/04/11 Javascript
JQuery Tips相关(1)----关于$.Ready()
2014/08/14 Javascript
Jquery中扩展方法extend使用技巧
2014/08/24 Javascript
JS实现同时搜索百度和必应的方法
2015/01/27 Javascript
jQuery基于图层模仿五星星评价功能的方法
2015/05/07 Javascript
浅谈Javascript线程及定时机制
2015/07/02 Javascript
值得分享的轻量级Bootstrap Table表格插件
2016/05/30 Javascript
JS实现对中文字符串进行utf-8的Base64编码的方法(使其与Java编码相同)
2016/06/21 Javascript
详解Vue整合axios的实例代码
2017/06/21 Javascript
详解Node.js模板引擎Jade入门
2018/01/19 Javascript
在js代码拼接dom对象到页面上的模板总结
2018/10/21 Javascript
浅谈layui分页控件field参数接收对象的问题
2019/09/20 Javascript
Python连接mssql数据库编码问题解决方法
2015/01/01 Python
在Python中处理列表之reverse()方法的使用教程
2015/05/21 Python
一个基于flask的web应用诞生 组织结构调整(7)
2017/04/11 Python
高效测试用例组织算法pairwise之Python实现方法
2017/07/19 Python
Python语言生成水仙花数代码示例
2017/12/18 Python
浅谈Python2、Python3相对路径、绝对路径导入方法
2018/06/22 Python
scikit-learn线性回归,多元回归,多项式回归的实现
2019/08/29 Python
python groupby 函数 as_index详解
2019/12/16 Python
英国Office鞋店德国网站:在线购买鞋子、靴子和运动鞋
2018/12/19 全球购物
Bluebella法国官网:英国性感内衣品牌
2019/05/03 全球购物
ManoMano英国:欧洲第一家专注于DIY和园艺市场的电商平台
2020/03/12 全球购物
经典商业广告词
2014/03/13 职场文书
校园环保标语
2014/06/13 职场文书
2014银行领导班子四风对照检查材料思想汇报
2014/09/25 职场文书
作风建设年度心得体会
2014/10/29 职场文书
2014年会计人员工作总结
2014/12/10 职场文书
redis 限制内存使用大小的实现
2021/05/08 Redis
一文带你探究MySQL中的NULL
2021/11/11 MySQL
“鬼灭之刃”热度不减,其成功背后的原因是什么?
2022/03/22 日漫