Vue2 移动端大屏适配,pc也可以

  1. 插件安装
npm i lib-flexible
npm i px2rem-loader // 自动将px转换为rem
npm i postcss-pxtorem  // 自动将px转换为rem
  1. 插件使用
// main.js
import 'lib-flexible'
  1. 插件配置
// vue.config.js
module.exports = {
  css: {
    loaderOptions: {
      postcss: {
        plugins: [
          require('postcss-px2rem')({
            remUnit: 192 // 1920设计稿
          })
        ],
        dist: {
          src: 'src/*.css',
          dast: 'build'
        }
      }
    }
  },
// 配置px2rem-loader
chainWebpack(config) {
 config.module
    .rule('css')
    .test(/\.css$/)
    .oneOf('vue')
    .use('px2rem-loader')
    .loader('px2rem-loader')
    .options({
      remUnit: 192, // 根据视觉稿,rem为px的十分之一,1920px  192 rem
      remPrecision: 8 // 换算的rem保留几位小数点
    })
}
  1. 使用postcss-pxtorem适配: 与src平级创建postcssrc.js文件(有个.)
// .postcssrc.js
module.exports = {
  plugins: {
    autoprefixer: {
      overrideBrowserslist: ['Android 4.1', 'iOS 7.1', 'Chrome > 31', 'ff > 31', 'ie >= 8']
    },
    'postcss-pxtorem': {
      rootValue: 37.5,
      propList: ['*'],
      //selectorBlackList: ['van-'] // 使用vant库
    }
  }
}
  1. 修改flexible.js
  • 找到node_modules下的lib-flexible插件
  • 根据需求修改refreshRem方法
  • 重启项目
function refreshRem() { 
  var width = docEl.getBoundingClientRect().width;
  if (width / dpr > 540  ) {
       // width = 540 * dpr; // 原先的数据
       width =  width * dpr;
  }
  var rem = width / 10; 
  docEl.style.fontSize = rem + 'px';
  flexible.rem = win.rem = rem;
} 
  • 注: px2rem-loader 与 postcss-pxtorem 一个就成,其余配置一样
Vue.js是一个流行的前端JavaScript框架,用于构建用户界面。Vue 2在移动端适配方面,主要涉及响应式布局、单位转换、适配方案等问题。下面简要介绍Vue 2移动端适配的几个关键点: 1. **单位转换**:在移动端开发中,常常使用`px`作为布局单位,但为了更好的适应不同屏幕尺寸,通常会将`px`转换为`rem`。`rem`是相对于根元素`html`的字体大小的单位,这意味着可以通过调整根元素的字体大小来统一控制页面中的尺寸。 2. **viewport设置**:通过设置`viewport`元标签,可以控制页面的布局视口,使其适应不同设备的屏幕尺寸。例如: ```html <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> ``` 其中`width=device-width`让布局视口等于设备宽度,`initial-scale=1`设置了初始缩放比例。 3. **媒体查询**:利用CSS的媒体查询可以根据不同的屏幕尺寸应用不同的样式规则。例如: ```css @media (max-width: 768px) { .my-class { font-size: 14px; } } ``` 这样,在宽度小于768像素的设备上,`.my-class`中的字体大小会调整为14像素。 4. **响应式组件**:在Vue 2中可以创建响应式的组件,根据设备的尺寸变化来改变组件的行为或样式。Vue的`v-bind`指令可以绑定一个JavaScript表达式,这使得我们可以通过一些计算来动态调整元素的样式。 5. **第三方库**:存在一些第三方库如`Flexible`、`postcss-pxtorem`等,可以帮助开发者快速实现单位转换和自动适配。 6. **Vue插件**:一些Vue插件如`vux`提供了移动端UI组件,可以简化移动端开发的流程,并且考虑到了移动端适配问题。 在实现移动端适配时,需要综合考虑以上几点,根据项目需求和设计目标选择合适的适配方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值