在 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";
}
相关推荐
q***952219 小时前
SpringMVC 请求参数接收
前端·javascript·算法
|晴 天|19 小时前
Vite 为何能取代 Webpack?新一代构建工具的崛起
前端·webpack·node.js
带只拖鞋去流浪19 小时前
迎接2026,重新认识Webpack5
前端·webpack
HIT_Weston19 小时前
43、【Ubuntu】【Gitlab】拉出内网 Web 服务:静态&动态服务
前端·ubuntu·gitlab
LucidX19 小时前
Web——反向代理、负载均衡与 Tomcat 实战部署
前端·tomcat·负载均衡
sen_shan20 小时前
《Vue项目开发实战》第八章:组件封装--vxeGrid
前端·javascript·vue.js
五点六六六20 小时前
双非同学校招笔记——离开字节入职小📕
前端·面试·程序员
IT_陈寒20 小时前
Redis实战:5个高频应用场景下的性能优化技巧,让你的QPS提升50%
前端·人工智能·后端
2***574220 小时前
Vue项目国际化实践
前端·javascript·vue.js
我也爱吃馄饨20 小时前
写的webpack插件如何适配CommonJs项目和EsModule项目
java·前端·webpack