【问题标题】:What does symbol tilde (~) mean in CSS [duplicate]CSS中的符号波浪号(〜)是什么意思[重复]
【发布时间】:2013-03-06 11:14:16
【问题描述】:

我想知道 (~) 在 css 中是什么意思。

#img1:hover ~ #img2 {
    opacity: 0;
}

在 Visual Studio 中,使用此符号时出现“意外字符序列”错误。这在 CSS 中的实际含义是什么。它有什么作用?

【问题讨论】:

    标签: css tilde


    【解决方案1】:

    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&lt;pre&gt;标签必须紧跟在&lt;h1&gt;之后

    【讨论】:

      【解决方案2】:

      如果它们出现在匹配第一个选择器的元素之后,它会将样式应用于匹配第二个选择器的所有元素。例如,给定一个 HTML sn-p 和 CSS 规则:

      hr ~ p {
          font-weight: bold;
      }
      <p>Line one</p>
      <hr />
      <p>Line two</p>
      <p>Line three</p>

      只有&lt;p&gt;Line two&lt;/p&gt;&lt;p&gt;Line three&lt;/p&gt; 会显示为粗体。在您的示例中,我认为 Visual Studio 在解释 :hover 修饰符时遇到问题,因为它并不是真正的元素。如果将其从规则中删除,它可能会正常工作。

      【讨论】:

      • 您是否注意到在各种浏览器中使用 ~ 有任何问题?最新的 Chrome 似乎对我忽略了它。
      • 我构建了一个非常简单的[index.html],只包含上面的例子。它显示正确,因此我打开了“关于”页面以获取版本号以向您报告。我在 Chrome 70 上,但导航到该页面开始了更新过程。完成后,我重新启动并再次尝试。因此,我可以说它适用于 Chrome 70 和 71。您可能需要确保没有任何东西会覆盖您的样式。
      猜你喜欢
      • 1970-01-01
      • 2011-09-22
      • 1970-01-01
      • 1970-01-01
      • 2012-05-28
      • 2017-01-28
      • 2015-06-24
      • 1970-01-01
      相关资源
      最近更新 更多