在 Vue 3 + Vite 项目中使用 Less 实现自适应布局:VW 和 VH 的应用

1. less的计算代码

css 复制代码
@charset "utf-8";
 
// 默认设计稿的宽度(根据开发UI稿更改)
@designWidth: 1920;

// 默认设计稿的高度(根据开发UI稿更改)
@designHeight: 1080;

.vw(@name, @px) {
      @{name}: (@px / @designWidth) * 100vw;
}

.vh(@name, @px) {
      @{name}: (@px / @designHeight) * 100vh;
}

.font(@px) {
      font-size: (@px / @designWidth) * 100vw;
}

2. vite.config.js里面的配置

javascript 复制代码
// https://vite.dev/config/
export default defineConfig(({ mode }) => {
  const { VITE_WEB_BASE_URL, VITE_WEB_PROXY_TARGET } = loadEnv(mode, process.cwd(), '')
  return {
    plugins: [
      vue(),
    ],
    css: {
      preprocessorOptions:{
        less:{
          additionalData:`@import "@/styles/utils.less";` //less工具函数的目录文件 一定要加分号
        }
      }
    },
    // 别名配置
    resolve: {
      alias: {
        '@': path.resolve(__dirname, './src'),
      }
    },
  }
})

3. 使用

css 复制代码
.header-icon {
  .vw(width, 16);
  .vh(height, 18);
  display: flex;
  align-items: center;
  justify-content: center;
}
.result-title {
  width: 100%;
  color: #ffffff;
  .font(18);
  font-weight: 400;
  font-family: "SourceHanSansCN";
}
相关推荐
Taiyuuki17 小时前
WebGPU 开发者福音!在 VS Code 中实时预览你的WGSL着色器作品
前端·gpu·图形学
李剑一17 小时前
uni-app实现网络离线定位
前端·trae
鲨莎分不晴17 小时前
Nginx 部署前端项目实战指南
运维·前端·nginx
码界奇点17 小时前
基于Vue3与TypeScript的后台管理系统设计与实现
前端·javascript·typescript·vue·毕业设计·源代码管理
ashcn200117 小时前
水滴按钮解析
前端·javascript·css
攀登的牵牛花17 小时前
前端向架构突围系列 - 框架设计(五):契约继承原则
前端·架构
爱吃奶酪的松鼠丶17 小时前
React长列表,性能优化。关于循环遍历的时候,key是用对象数据中的ID还是用索引
javascript·react.js·性能优化
xkxnq18 小时前
第二阶段:Vue 组件化开发(第 17天)
javascript·vue.js·ecmascript
豆苗学前端18 小时前
你所不知道的前端知识,html篇(更新中)
前端·javascript·面试
一 乐18 小时前
绿色农产品销售|基于springboot + vue绿色农产品销售系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端·宠物