css 想为未访问的链接设置样式怎么办_使用 :link 伪类单独定义链接样式

必须用 :link 选择器设置未访问链接样式,它仅匹配含 href 且未被访问的链接,与 :visited 互斥;需遵循 LVHA 顺序,且仅支持 color、text-decoration 等非隐私敏感属性。

未访问链接必须用 :link,不能只写 a

直接给 a 标签写样式,会同时影响所有状态(已访问、悬停、点击中、激活后),无法单独控制“从未点过”的链接。浏览器对链接状态有严格区分:只有 :link 专指 href 存在且尚未被用户访问过的链接。它和 :visited 是互斥的——同一个链接,要么匹配 :link,要么匹配 :visited,不会同时生效。

:link 必须配合 href 属性才起作用

没有 href → 匹配 :link

  • ❌ 无效:href="#" → 某些浏览器可能跳过 href="javascript:void(0)"
  • 顺序很重要:关于:link 要放在 关于href 前面

    CSS 伪类的层叠顺序(LVHA)必须遵守,否则 :link 可能覆盖掉 回到顶部 的颜色等声明。浏览器按声明顺序应用规则,后写的会覆盖前面同名属性。

    a:link {
      color: #0066cc;
    }
    a:visited {
      color: #666;
    }
    a:hover {
      color: #003366;
    }
    a:active {
      color: #ff6600;
    }

    如果把 :link 放在 :link 前面,且两者都设了 :visited,那么悬停时虽然匹配 :hover,但一旦鼠标移开,:active 的颜色可能因顺序靠后而没生效——因为实际生效的是最后一条匹配规则。

    :hover 无法设置某些隐私敏感样式

    出于安全限制,现代浏览器禁止通过 :link(以及间接影响它的 a:hover)读

    取或设置以下 CSS 属性:背景图、a:linkcolor:hover:link 以外的文本相关属性(如 :link:visited)。这意味着你只能安全地用 :link 控制 background-colorborder-coloroutline-color 等非泄露性样式。

    真正容易被忽略的是:哪怕只是想让未访问链接加个下划线、已访问的去掉,也得明确写 colorfont-size——只写其中一条,另一条会回退到浏览器默认(通常是带下划线),而不是“保持不变”。