首页 > 语言 > JavaScript > 正文

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

2024-05-06 15:30:40
字体:
来源:转载
供稿:网友

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="https://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    })  })}            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选