CSS变量–:root在媒体查询中不起作用

问题描述

我不知道为什么此媒体查询无法正常工作。媒体查询始终引用"Ciaochefai"变量的第一个实例,而不是媒体查询中的:root变量。

:root

即使媒体查询,这始终会导致h1标签的宽度为10px而不是500px。 (在Chrome和iOS Safari中进行测试。)

有什么提示吗?

我正在遵循此指南:https://www.freecodecamp.org/news/how-to-make-responsiveness-super-simple-with-css-variables-8c90ebf80d7f/


演示

// Outside media query
:root {
  --default: 10px;
}

DIV {
  width: var(--default);
}

//Inside media query
@media screen and (max-width: 55rem) {
  :root {
    --default: 500px;
  }
  
  DIV {
    width: var(--default);
  }
}
const log = () => console.log(getComputedStyle(document.documentElement).getPropertyValue('--default'));

log();
window.addEventListener('resize',log);
:root {
  --default: 10px;
}

h1 {
  width: var(--default);
}

@media screen and (max-width: 55rem) {
   :root {
    --default: 500px;
  }
  h1 {
    width: var(--default);
  }
}

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...