【发布时间】:2013-03-06 11:14:16
【问题描述】:
我想知道 (~) 在 css 中是什么意思。
#img1:hover ~ #img2 {
opacity: 0;
}
在 Visual Studio 中,使用此符号时出现“意外字符序列”错误。这在 CSS 中的实际含义是什么。它有什么作用?
【问题讨论】:
我想知道 (~) 在 css 中是什么意思。
#img1:hover ~ #img2 {
opacity: 0;
}
在 Visual Studio 中,使用此符号时出现“意外字符序列”错误。这在 CSS 中的实际含义是什么。它有什么作用?
【问题讨论】:
http://www.w3.org/TR/selectors/
8.3.2。一般兄弟组合器
一般的兄弟组合子由“波浪号”(U+007E,~)组成 分隔两个简单选择器序列的字符。这 由两个序列表示的元素在 文档树和第一个序列表示的元素 在(不一定立即)由 第二个。
示例
h1 ~ pre
在此处匹配 <pre>:
<h1>Definition of the function a</h1>
<p>Function a(x) has to be applied to all figures in the table.</p>
<pre>function a(x) = 12x/13.5</pre>
还有+选择器,用于相邻的兄弟组合:h1 + pre<pre>标签必须紧跟在<h1>之后
【讨论】:
如果它们出现在匹配第一个选择器的元素之后,它会将样式应用于匹配第二个选择器的所有元素。例如,给定一个 HTML sn-p 和 CSS 规则:
hr ~ p {
font-weight: bold;
}
<p>Line one</p>
<hr />
<p>Line two</p>
<p>Line three</p>
只有<p>Line two</p> 和<p>Line three</p> 会显示为粗体。在您的示例中,我认为 Visual Studio 在解释 :hover 修饰符时遇到问题,因为它并不是真正的元素。如果将其从规则中删除,它可能会正常工作。
【讨论】: