我无法从我能找到的任何解释中确定关于何时设置 css 变量的值。所以我进行了测试
html
<div class="flex">
<div class="item1">
<div class="included"></div>
</div>
<div class="item2">
<div class="included"></div>
</div>
</div>
css
:host {
display: grid;
place-content: center;
}
.flex {
display: flex;
flex-direction: column;
width:800px;
height: 300px;
background-color: blue;
--div-width: calc(100% - 10px);
}
.item1,.item2 {
background-color: green;
height: 100px;
}
.item1 {
width: 80%;
}
.item2 {
width: 40%;
}
.included {
width: var(--div-width);
background-color:yellow;
height:50px;
}
注意我在自定义元素中进行了测试,因此 :host
描述符,但这并不重要。
重要的是我在 800 像素宽的 div 中将 --div-width
设置为 calc(100% - 10px)
- 所以期望它具有 790 像素的值。
很明显,计算被延迟到使用变量的地方。因为黄色框距离周围元素仅 10 像素。
有没有办法告诉 css 将属性的值设置为声明它的元素,而不是使用它的地方。
我确实尝试代理变量 - 就像这样......
--proxy-width: calc(100% - 10px);
--div-width: var(--proxy-width);
但没有区别。
PS 这是一个简单的例子,我实际上想如何使用它来控制自定义元素内项目(文本区域)的宽度,取决于上下文,因此我可以使元素响应一些外部容器的宽度。