媒体查询动态修改less变量

背景

有个网站需要兼容手机和pc,对字体做了变量处理,考虑的是在媒体查询时,修改less的变量值,从而兼容,不需要去逐个修改元素的字体了。

解决方案

实现代码如下,原理是在媒体查询中动态修改css变量

less 复制代码
:root {
  --font-color: #363636;
  --font-size-medium: 16px;
  --font-size-small: 14px;
  --font-size-x-small: 12px;
  --font-size-large: 24px;
}

@font-color: var(--font-color);
@font-size-medium: var(--font-size-medium);
@font-size-small: var(--font-size-small);
@font-size-x-small: var(--font-size-x-small);
@font-size-large: var(--font-size-large);

// 手机端适配
@media screen and (max-width: 768px) {
  :root {
    --font-size-large: 16px;
    --font-size-medium:14px
  }
}

思考过程

初始代码如下,最初想直接修改less变量

less 复制代码
@font-color: #333333;
@font-size-medium: 16px;


@media screen and (max-width: 768px) {
  @font-color: #666666;
  @font-size-medium: 14px;
}

结果媒体查询less变量更改不生效,查了一些资料,有的说使用modifyVars 方法来修改,如下所示,同样不生效

js 复制代码
import less from 'less'

const modifyVars = () => {
  less.modifyVars({
    '@font-color': 'red'
  })
}

猜测是less的变量在编译成css之后,已经是具体的值,不具有动态变化的情况

less编译成css,直接用less变量,编译后如下

使用css变量,后面在媒体查询里修改 --font-color,会刷新css样式。

相关推荐
未来之窗软件服务44 分钟前
打开所在文件路径,鸿蒙系统,苹果macos,windows,android,linux —智能编程—仙盟创梦IDE
前端·ide·资源管理器·仙盟创梦ide
houzhizhen1 小时前
SQL JOIN 关联条件和 where 条件的异同
前端·数据库·sql
^小桃冰茶5 小时前
CSS知识总结
前端·css
巴巴_羊6 小时前
yarn npm pnpm
前端·npm·node.js
chéng ௹7 小时前
vue2 上传pdf,拖拽盖章,下载图片
前端·css·pdf
嗯.~7 小时前
【无标题】如何在sheel中运行Spark
前端·javascript·c#
A_aspectJ10 小时前
【Bootstrap V4系列】学习入门教程之 组件-输入组(Input group)
前端·css·学习·bootstrap·html
兆。10 小时前
电子商城后台管理平台-Flask Vue项目开发
前端·vue.js·后端·python·flask
互联网搬砖老肖10 小时前
Web 架构之负载均衡全解析
前端·架构·负载均衡
sunbyte11 小时前
Tailwind CSS v4 主题化实践入门(自定义 Theme + 主题模式切换)✨
前端·javascript·css·tailwindcss