a标签伪类:visited下划线和背景图设置无效的原因

今天在学习用背景图设计项目符号的时候,发现了在 a:visited 伪类选择器里对设置的下划线(text-decoration:underline)和背景图(background:)都不起作用,仅仅对颜色(color)属性有效,很是纠结。

------------------------------------------------------------------------------------
更新于2017/9/24。有关a:visited 有关伪类选择器的color 属性补充。
再做网页小导航条的时候无意间发现了,这个问题在不同浏览器的区别,于是前来于此做一下笔记,一遍日后参考,话不多说,就拿我今天写的导航条为例吧具体如下(完整的代码我就不写了,只把有关此内容的核心代码贴出来吧):

    .test a:link {
        color:#666;/*我们把这个颜色称为 浅灰 吧*/
        text-decoration:none;
    }
    .test a:visited {
        color:#f00;/*我们把这个颜色称为 橘红 吧*/
        text-decoration:underline;/*下划线肯定是无效的*/
    }

IE浏览器中的效果图(我只点击了-博客-这个链接):

IE中浏览器中访问其中之一后的超链接的效果.png

很明显上面的代码得到了,点击-博客-后,字体颜色如愿以偿的 由 浅灰 变为 橘红 ,很好的体现在IE浏览器中。
我们再来看一下在 谷歌和火狐 浏览器中的效果:

谷歌、火狐浏览器中超链接的效果.png
谷歌、火狐浏览器中访问其中之一后的超链接的效果.png

在 谷歌和火狐 浏览器中,点击-博客-后,所有超链接的字体颜色都的 由 浅灰 变为 橘红 ,不难想象这也是出于网络安全的考虑(不懂,请继续往下看。),我们在实际应用中记住这些差异即可(其他浏览器为测试,建议阅读者可自行测试)。

------------------------------------------------------------------------------------
代码:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>使用背景图设计项目符号</title>
<style type="text/css">
    ul{
        list-style:none;
        width:20em;
        padding:0;
        border-bottom:1px dashed #aaa;
    }
    li{
        border-top:1px dashed #aaa;
        margin:0;
        padding:0.5em;
        
    }
    li a{
        display:block;
        padding-left:1.5em;
        text-decoration:none;
    }
    li a:link{

        background:url(images/arrow3.gif) no-repeat center right;
    }
    li a:visited{
        text-decoration:underline;
        background:url(images/arrow4.gif) no-repeat center right;
    }
    li a:hover{
        background:url(images/arrow4.gif) no-repeat center left;
        
    }
    
    
</style>
</head>

<body>
<h1>新闻</h1>
<ul>
    <li><a href="#">军事</a></li>
    <li><a href="#">财经</a></li>
    <li><a href="#">体育</a></li>
    <li><a href="#">娱乐</a></li>
    <li><a href="#">科技</a></li>
</ul>

</body>
</html>

ie、谷歌等浏览器效果:

未访问效果.png
鼠标经过效果.png
访问后效果.png

可以看出访问后的并没有出现下划线和背景图。经查阅资料终于解决了我的疑惑。

资料:

Why the :visited Pseudo-class is Strange

Modern browsers have severely restrained the CSS properties that developers can use in a style rule that uses the :visited link pseudo-class. If you’re unfamiliar with this oddball pseudo-class, you may be wondering why your site’s visited links aren’t rendering as expected.

If you try to style visited links by giving them a background-image, for instance, you’ll be surprised that you can no longer do so in modern browsers. You might think it’s a browser bug because there’s no immediately obvious reason why the following CSS doesn’t work:

/* this will not work as expected */
a:visited {
display: block;
background-image: url("cat.jpg");
}
If we use any other pseudo-class — like, say, the :hover pseudo-class — the style properties work as expected.

/* this is perfectly fine */
a:hover {
display: block;
background-image: url("cat.jpg");
}
Currently, it seems like the only property you can assign to the :visited pseudo-class is the color property. Oh, and the browser in all likelihood won’t render the color with an alpha transparency even if you correctly specify it with a standard color unit like rgba.

Strange right? What’s up?

The W3C specifications for the link pseudo-classes technically gives web browsers the option to ignore our :link and :visited pseudo-class style rules. This is because the :visited pseudo-class can be potentially abused in such a way that an abuser can get data about its visitors’ browsing history.

It is possible for style sheet authors to abuse the :link and :visited pseudo-classes to determine which sites a user has visited without the user’s consent.

UAs may therefore treat all links as unvisited links, or implement other measures to preserve the user’s privacy while rendering visited and unvisited links differently."

Source: Selectors Level 3: The link pseudo-classes: :link and :visited

(In case you’re wondering: In the above excerpt, the term "UAs" refers to "user agents", which is software that’s used to access a website. The most common type of UA is a web browser.)

How a User’s Browsing History Could Be Compromised

To explain the reason why you can’t use all CSS properties with the :visited pseudo-class, I will attempt to explain it through a hypothetical situation.

Modern browsers no longer allow the background-image property to render.

省略......

点击查看上面原文。

翻译(英语不好实在看不下去了,只翻译了上面这部分):

为什么:访问伪类是奇怪的?

现代浏览器严重限制了开发人员可以在样式规则中使用的CSS属性,该样式规则使用:访问链接伪类。如果你不熟悉这个古怪的伪类,你可能想知道为什么你的网站的访问过的链接没有呈现预期。
如果你试着通过给他们一个背景图像来设计访问的链接,你会惊讶于你不再能在现代浏览器中这样做了。你可能认为这是一个浏览器错误,因为没有明显的理由说明下面的CSS不起作用:

/ *这将不象预期的那样工作。*/
a:visited {
  display: block;
  background-image: url("cat.jpg");
}

如果我们使用其他任何伪类,比如:悬停伪类,样式属性就如预期的那样工作。

/*这是完全正确的*/。
a:hover {
  display: block;
  background-image: url("cat.jpg");
}

目前,它似乎是惟一可以赋予的属性:访问的伪类是颜色属性。哦,在所有可能的浏览器不会呈现颜色的alpha透明度即使你正确地指定它与标准颜色单元如RGBA。
陌生吗?出什么事了?
W3C规范的链接伪类在技术上提供了Web浏览器忽略我们的选项:link 和 :visited伪类样式规则。这是因为::visited伪类可以潜在的滥用使得网络施虐者可以获得访问者的浏览历史记录的数据。
样式表作者可能会滥用:链接和访问的伪类,以确定用户在未经用户同意的情况下访问了哪些站点。
浏览器可能会把所有链接中未访问的链接,或采取其他措施来保护用户的隐私而渲染访问和未访问的链接是不同的。”

用户的浏览历史如何被破坏
为了解释为什么不能将所有CSS属性用于:visited,我将尝试通过假设的情况来解释它。

现代浏览器不再允许背景图像属性渲染。

总结:
  a:visited伪类可能会暴露用户浏览信息记录,攻击者可能会据此判断用户曾经访问过的网站,造成不必要的损失,因此这些浏览器决定限制a:visited的功能,所以不是代码的问题,而是浏览器方面的限制。
  所以,若是用下划线或背景图来判断某链接是否曾被点击过是失效的,那么我们就只能通过设置颜色来区别了,这时候我们就要严格遵从lvha规则了(但在写小demo学习时又会发现有时候页面在经过改动后刷新会自动显示链接的颜色为:visited设置中的颜色,这是因为浏览器缓存的原因,在做小demo时可采用头部meta编码使其不再保留缓存)。

附:但书写时也要注意link--visited--hover-active顺序不能颠倒。
  老外总结了一个便于记忆的“爱恨原则”(LoVe/HAte),即四种伪类的首字母:LVHA。定义a链接样式的正确顺序:a:link、a:visited、a:hover、a:active。

声明:此文只代表个人见解,只供参考!联系QQ:1522025433

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文转载自:众成翻译译者:为之漫笔链接:http://www.zcfy.cc/article/239原文:http...
    极乐君阅读 12,101评论 1 62
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,399评论 19 139
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,683评论 1 92
  • :hover{}为什么要在下面? a连接常用的伪类选择器有四种,根据CSS文档的推荐,这四个选择器最好按如下方式排...
    朱小维阅读 4,882评论 0 0
  • 用处 普通基于元素或基于类的样式定义像这样 p {color: red;text-align: center;}这...
    西北偏北阅读 5,117评论 1 3