vue element-ui响应式布局(记录)

1.可以实现Vue移动端和PC端的响应式布局适配
实现方法:通过 postcss-px-to-viewport 来自动将我们开发时的px单位计算转换为vw/rem视口单位,完成响应式布局 。

安装插件

npm安装
npm install postcss-px-to-viewport -S 
npm安装
npm install postcss-px20px -S 
npm安装
npm install postcss-px20px -S 

PC端适配,在项目根目录下创建 postcss.config.js 配置文件

module.exports = {
    plugins: {
      'postcss-px-to-viewport': {
        unitToConvert: 'px', // 需要转换的单位,默认为"px"
        viewportWidth: 1920, // 设计稿的视口宽度
        unitPrecision: 3, // 单位转换后保留的精度
        propList: ['*'], // 能转化为vw的属性列表
        viewportUnit: 'rem', // 希望使用的视口单位
        fontViewportUnit: 'rem', // 字体使用的视口单位
        selectorBlackList: [], // 需要忽略的CSS选择器,不会转为视口单位,使用原有的px等单位。
        minPixelValue: 1, // 设置最小的转换数值,如果为1的话,只有大于1的值会被转换
        mediaQuery: true, // 媒体查询里的单位是否需要转换单位
        replace: true, //  是否直接更换属性值,而不添加备用属性
        exclude: [/node_modules/, /LargeScreen/], // 忽略某些文件夹下的文件或特定文件,例如 'node_modules' 下的文件,数组中写正则
        include: undefined, // 如果设置了include,那将只有匹配到的文件才会被转换
        landscape: false, // 是否添加根据 landscapeWidth 生成的媒体查询条件 @media (orientation: landscape)
        landscapeUnit: 'vw', // 横屏时使用的单位
        landscapeWidth: 1920, // 横屏时使用的视口宽度
      },
    },
  };
  
  

移动端适配,也是在根目录下创建 postcss.config.js 配置文件,不过配置内容要改变一下。
在写项目的时候,会用到第三方ui组件库,比如vant…,此时你会发现vant组件的尺寸会小一半,那是因为vant官方是用375设计稿,你用的是750,动态判断就好。
下面代码的作用主要是用来判断读取的是否是ui组件库ant-design-vue的文件,如果是,视口的宽度就设置为375,其他的文件则按照ui稿的宽度750

const path = require('path')

module.exports = ({ file }) => {
  const designWidth = file.dirname.includes(
    path.join('node_modules', 'ant-design-vue')
  )
    ? 375
    : 750

  return {
    plugins: {
      autoprefixer: {}, // 用来给不同的浏览器自动添加相应前缀,如-webkit-,-moz-等等
      'postcss-px-to-viewport': {
        unitToConvert: 'px', // 要转化的单位
        viewportWidth: designWidth, // UI设计稿的宽度
        unitPrecision: 6, // 转换后的精度,即小数点位数
        propList: ['*'], // 指定转换的css属性的单位,*代表全部css属性的单位都进行转换
        viewportUnit: 'vw', // 指定需要转换成的视窗单位,默认vw
        fontViewportUnit: 'vw', // 指定字体需要转换成的视窗单位,默认vw
        selectorBlackList: [], // 指定不转换为视窗单位的类名,
        minPixelValue: 1, // 默认值1,小于或等于1px则不进行转换
        mediaQuery: true, // 是否在媒体查询的css代码中也进行转换,默认false
        exclude: [], // 设置忽略文件,用正则做目录名匹配
        landscape: false, // 是否处理横屏情况
        // replace: true, // 是否转换后直接更换属性值
      },
    },
  }
}

PC端适配,在项目utils目录下创建 pxtorem.js 文件

// rem等比适配配置文件
// 基准大小
const baseSize = 20
// 设置 rem 函数
function setRem () {
  // 当前页面宽度相对于 1920宽的缩放比例,可根据自己需要修改。
  const scale = 1 //document.documentElement.clientWidth / 1920
  // 设置页面根节点字体大小(“Math.min(scale, 2)” 指最高放大比例为2,可根据实际业务需求调整)
  document.documentElement.style.fontSize = baseSize * Math.min(scale, 2) + 'px'
}
// 初始化
setRem()
// 改变窗口大小时重新设置 rem
window.onresize = function () {
  setRem()
}

将 pxtorem.js 文件引入main.js

import './utils/pxtorem'

在app.vue中配置一下

<template>
  <div id="app" ref="newCatalog">
    <router-view name="head" ></router-view>
    <router-view name="body"></router-view>
    <router-view name="foot"></router-view>
  </div>
</template>

<script>

export default {
  name: 'App',
  components: {
  },
  data() {
    return {
      scale: ''
    }
  },
  mounted() {
    this.setScale()
    window.addEventListener('resize', this.setScale)
  },
  methods: {
    getScale() {
      const width = window.screen.width
      const height = window.screen.height
      let ww = window.innerWidth / 1920
      let wh = window.innerHeight / 1080
      return ww < wh ? ww : wh
    },
    setScale() {
      this.scale = this.getScale()
      this.$refs.newCatalog.style.setProperty('--scale', this.scale)
    }
  }
}
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #333333;
  min-width: 1200px;
  scale: 1;
}
</style>

配置好文件以后,重启项目就行,也可以不用重启,编译一下就行,可以测试一下。

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Vue Element-UI适配移动端需要注意以下几点: 1. 使用响应式布局Element-UI提供了响应式布局的组件,可以根据屏幕大小自动调整布局,适应不同的设备。 2. 自定义主题:Element-UI提供了主题定制的功能,可以根据需要自定义主题,使得UI更加适合移动端的使用。 3. 使用移动端组件:Element-UI提供了一些专门针对移动端的组件,如下拉刷新、无限滚动等,可以提高移动端的用户体验。 4. 优化性能:移动端设备的性能相对较弱,需要注意优化组件的性能,减少不必要的渲染和计算。 总之,Vue Element-UI适配移动端需要综合考虑布局、主题、组件和性能等方面的因素,才能达到最佳的效果。 ### 回答2: Vue Element-UI是一个流行的UI框架,可帮助开发人员在Vue.js中构建灵活且易于定制的用户界面。虽然Vue Element-UI本来是针对桌面应用程序开发的,但也可以适应移动端。 有几种方法可以使Vue Element-UI适配移动端,其中一种是使用媒体查询和CSS样式,以便元素在不同屏幕尺寸下响应式地显示。Vue Element-UI大多使用Flex布局,这使得在移动设备上自适应变得更加容易。 另一种方法是在Vue Element-UI的基础上扩展移动端UI组件。这种方法旨在优化用户体验和交互。调整一些UI组件的布局和交互元素,例如菜单、按钮和表单,以适应移动设备的触摸屏幕。 除了前述两种方法,还有一些移动端UI框架,可与Vue Element-UI集成,以便简化适配移动端的流程。例如,Vant是一种基于Vue.js的移动端UI组件库,而Element Mobile是专为移动Web应用程序开发而设计的组件框架。 总之,Vue Element-UI可以轻松适应移动端应用程序的开发,开发人员可以通过使用CSS样式,扩展UI组件或与其他移动端UI框架集成,来调整UI元素和提高用户体验。 ### 回答3: Vue Element-UI是一个基于Vue.js框架的组件库,它提供了丰富的UI组件和良好的可定制性和易用性,让开发人员可以快速构建出美观且交互友好的Web应用程序。但是,由于Vue Element-UI最初是为桌面端设计而开发的,因此在移动端上使用时需要进行一些适配工作。 1. 引用Vue Element-UI的样式 在移动端项目里使用Vue Element-UI时,需要在项目中引入组件库的样式文件。使用Vue CLI创建的Vue项目,可以在main.js中全局引入: import 'element-ui/lib/theme-chalk/index.css'; 如果使用按需加载,则需要在需要使用组件的地方单独引入样式。 2. 调整组件尺寸和响应式 因为移动设备的屏幕尺寸比桌面端小,所以使用组件时需要对其进行大小和布局的适配。可以通过修改组件中size属性的值来调整尺寸,或通过在组件外层嵌套一个容器元素并设置其宽度来使组件自适应布局。在一些特殊情况下,需要针对具体组件进行样式调整才能达到最佳效果。 3. 优化交互体验 移动端的交互方式和桌面端大不相同,用户习惯也有所差异。因此在使用Vue Element-UI时,需要考虑优化交互体验,比如通过添加手势操作、隐藏不必要的按钮、调整布局等来提高用户体验。 4. 开发响应式页面 在移动端上,用户可能不止使用一种设备和屏幕尺寸来访问网站或应用程序。为了适应不同设备的屏幕尺寸和分辨率,需要开发响应式页面,可以使用Vue Element-UI的栅格系统来实现。 总之,使用Vue Element-UI开发移动应用程序需要考虑的问题比较多,但只要针对具体情况进行适配和优化,就能够开发出优秀的Web应用。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值