vue pc端网页实现自适应

一、基本原理

pc端做自适应可以用rem来实现,啥是rem,自己百度

二、新建rem.ts文件

javascript 复制代码
// rem等比适配配置文件
// 基准大小
const baseSize = 14
// 设置 rem 函数
function setRem () {
  // 当前页面宽度相对于 1920宽的缩放比例,可根据自己需要修改。这里的1920是设计图的宽度
  const scale = document.documentElement.clientWidth / 1920;
  // 设置页面根节点字体大小
  document.documentElement.style.fontSize = baseSize * scale + 'px';
}
// 初始化
setRem()
// 改变窗口大小时重新设置 rem
window.addEventListener('resize',()=>{
  setRem()
})

这个文件可以根据屏幕大小来设置根节点字体的大小,记住这里的baseSize,然后在main.ts文件中引入

三、安装postcss-pxtorem依赖

javascript 复制代码
npm install postcss-px2rem px2rem-loader --save

在vite.config.ts文件中引入,我这项目用的是vue3 + vite + ts,你用的是webpack,那就在vue.config.js里面

javascript 复制代码
import postCssPxToRem from 'postcss-pxtorem';
export default defineConfig(({ mode }) => {
  return {
    plugins: [
      vue()
    ],
    css: {
      postcss: {
        plugins: [
          postCssPxToRem({
            // 自适应,px>rem转换
            rootValue: 14, // 这里不一定要14,但必须和rem.ts文件中的baseSize大小一样
            propList: ['*'], // 需要转换的属性,这里选择全部都进行转换
            selectorBlackList: ['norem'], // 过滤掉norem-开头的class,不进行rem转换
          }),
        ],
      },
    },
    resolve: {
      alias: {
        // @:src  读取当前src在本地的目录
        '@': resolve(__dirname, './src'),
        // 'HkWebVideoCtrl': resolve('src/assets/js/webVideoCtrl.js'),
      }
    },
    server: {
      host: '0.0.0.0',
      port: 8000,
      open: true,
    },
  };
})

然后就可以直接在css里面使用px了,这个依赖会自动把px转换成rem,包括ui框架里面的,比如elmentui里面的,这样全局的css样式都是rem了,但是有一个缺陷就是行内元素里面的px不能转换,比如 <div style="width:300px"></div>,这里的px就转换不了,所以还得手动写一个js

javascript 复制代码
// 获取当前屏幕大小与1920的比列,计算大小,这里的1920还是看设计图的宽度
export const getScaleByUI = (size: number) => {
  const scale = document.documentElement.clientWidth / 1920;
  return size * scale;
}

<div :style="{width:getScaleByUI (300) + 'px'}"></div>,但是不建议写在style里面,如果ui框架里面的样式用的是style,那就只能用穿透去修改了

这样所有的自适应就搞定了

相关推荐
剪刀石头布啊2 分钟前
iframe通信、跨标签通信的常见方案
前端·javascript·html
宇之广曜11 分钟前
搭建 Mock 服务,实现前端自调
前端·mock
yuko093112 分钟前
【手机验证码】+86垂直居中的有趣问题
前端
用户15129054522016 分钟前
Springboot中前端向后端传递数据的几种方式
前端
阿星做前端17 分钟前
如何构建一个自己的 Node.js 模块解析器:node:module 钩子详解
前端·javascript·node.js
用户15129054522020 分钟前
Web Worker:让前端飞起来的隐形引擎
前端
司宸21 分钟前
学习笔记十 —— 自定义hooks设计原则 笔试实现
前端
用户15129054522025 分钟前
踩坑与成长:WordPress、MyBatis-Plus 及前端依赖问题解决记录
前端·后端
半个烧饼不加肉31 分钟前
React + ts + react-webcam + CamSplitter 实现虚拟摄像头解决win摄像头独占的问题
前端·react.js·前端框架
上单带刀不带妹1 小时前
JavaScript 中的宏任务与微任务
开发语言·前端·javascript·ecmascript·宏任务·微任务