美文网首页
vue 3.x移动端适配

vue 3.x移动端适配

作者: 天上飞的狒狒 | 来源:发表于2023-09-12 10:33 被阅读0次
vue3中用 amfe-flexible + postcss-pxtorem

amfe-flexible:根据屏幕宽度,自动设置html的font-size
postcss-pxtorem:自动将px单位转换成rem

  • 首先需要在 index.html文件中的header标签里,以消除很多标签自带的padding和marging,
    设置最大宽度需要在index.html和app.vue里面同时设置最大宽度
  <style>
 /*消除很多标签自带的padding和marging */
    * {
      margin: 0;
      padding: 0;
    }
/*设置背景颜色*/
 body {
      background-color: #f4fdff;
    }
    /*设置最大宽度 */
    @media screen and (min-width: 500px) { 
      html {
        font-size: 50px !important;
      }
    }
    /*设置最小宽度 */
    @media screen and (max-width: 320px) {
      html {
        font-size: 32px !important;
      }
    }
  </style>
  • 再次为了使洁面适配大屏,需要在 app.vue里面设置
#app {
  margin: 0 auto;   /* 居中显示 */
  max-width: 420px;   /* 设置最大宽度显示 */
}
  • 其次 在index.html文件中 设置这段的目的是设置视口宽度,不允许用户缩放
 <!-- width: 设置布局视口的宽度  device-width是获取用户设备的宽度 -->
  <meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1, minimum-scale=1,user-scalable=no">
1.引入amfe-flexible
npm i -S amfe-flexible
2. 引入 postcss-pxtorem
npm install postcss-pxtorem --save-dev
3. 安装完后我们先在main.js中引入amfe-flexible
import 'amfe-flexible'
4 接着在项目"根目录"新建一个postcss.config.js文件

5. 或者可在vue.config.js、.postcssrc.js、postcss.config.js其中之一配置,权重从左到右降低,没有则新建文件,只需要设置其中一个即可
  • 1、 rootValue根据设计稿宽度除以10进行设置,这边假设设计稿为375,即rootValue设为37.5;
  • 2、propList是设置需要转换的属性,这边*为所有都进行转换。

1、在vue.config.js配置如下

module.exports = {
    css: {
        loaderOptions: {
            postcss: {
                plugins: [
                    require('postcss-pxtorem')({
                        rootValue: 37.5,
                        propList: ['*']
                    })
                ]
            }
        }
    },
}

2、或在.postcssrc.js或postcss.config.js中配置如下:

module.exports = {
            "plugins": {
                     autoprefixer: {},
                'postcss-pxtorem': {
                    rootValue: 75, //设计稿宽度的1/10。
                    propList: ['*'] //需要做转化处理的属性,如 height weidth margin 等,*表示全部
                }
            }
        }
5. 配置完之后我们就可以在项目中以px为单位去开发了,是的,不用我们手动敲rem转换去开发了,PS设计稿的宽度以750px为基准,否则需要自己调一下,开发时稿子是1px,你就写1px就好了,插件会帮我们换算成rem。
6实际的项目中,你测量的px是多少,就直接写多少px,转化为rem,无需自己计算

感谢以下链接支持
https://blog.csdn.net/weixin_42063951/article/details/127734001
https://blog.csdn.net/Orange71234/article/details/131329898

相关文章

  • 如何在Vue项目中使用vw实现移动端适配

    Vue项目中使用vw实现移动端适配 我们在vue移动端项目中的适配一般都采用rem,但是rem也不是能兼容所有的终...

  • 移动端如何适配?

    1、使用Flexible实现手淘H5页面的终端适配2、再聊移动端页面的适配3、如何在Vue项目中使用vw实现移动端...

  • vue移动端适配

    网址:https://segmentfault.com/a/11900000160398481.复制粘贴里面的JS...

  • Vue移动端适配

    一、配置flexible1、安装lib-flexible 2、全局引用文件(在mian.js中引入) 3、在项目根...

  • vue移动端适配

    首先安装插件 在main.js中进行引入 然后安装px转换为rem的插件 找到build文件夹下的utils.js...

  • vue 移动端适配

    vue适配:以750设计稿为基准,在不同屏幕尺寸下如何适配 Safari中设置了禁止用户缩放无效的问题: iOS ...

  • vue移动端适配

    在根目录的utils文件夹中新建rem.js,如果没有utils则自己新建,一般utils文件夹都是存放公用方法的...

  • vue 移动端适配

    这里我写一下我自己用的vue 移动端适配 ,可能跟别人的不一样。但是效果是一样的。我是安装 amfe-flexib...

  • vue 移动端适配

    一、方法一:rem 布局 在主入口:index.html, 标签内添加如下JS 代码:(实现在标准 375px宽...

  • vue 移动端适配

    1.安装配置PostCSS插件 2.在根目录.postcssrc.js文件中配置一下文件没有就新建一个 在inde...

网友评论

      本文标题:vue 3.x移动端适配

      本文链接:https://www.haomeiwen.com/subject/pcgyvdtx.html