在 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";
}
相关推荐
DanCheOo几秒前
多模型适配:一套代码接 6 家 AI 厂商
前端·ai编程
米丘1 分钟前
Node.js 事件循环
前端·javascript·node.js
Forever7_2 分钟前
紧急!Axios 被投毒,3亿项目受到影响!教你怎么自查!
前端·axios
zzialx1233 分钟前
HarmonyOS:照片添加多样式的水印信息
前端
前端冒菜师7 分钟前
记一次AI全栈开发的过程
前端·ai编程
Giant10014 分钟前
深度玩转 Cursor Rules:让 AI 生成的代码 100% 符合团队规范
前端·面试
代码煮茶17 分钟前
Vue3 组件通信实战 | 8 种组件通信方式全解析
前端·vue.js
kyriewen17 分钟前
自定义事件:让代码之间也能“悄悄对话”
前端·javascript·面试
子兮曰25 分钟前
别把它当成一次普通“源码泄露”:Claude Code 事件给 AI Agent 团队提了什么醒
前端·npm·claude
心之语歌35 分钟前
Vue2 data + Vue3 ref/reactive 核心知识点总结
开发语言·前端·javascript