背景
有个网站需要兼容手机和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样式。