博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
a标签4个伪类的顺序排列
阅读量:7060 次
发布时间:2019-06-28

本文共 1007 字,大约阅读时间需要 3 分钟。

与a标签有关的常用伪类包括4个,分别为:link、:visited、:hover、:active。在设置a标签的css样式时,需要设置的顺序为Love Hate(:link、:visited、:hover、:active)。

原因:浏览器的就近原则,举个例子:
我定义的顺序是a:visited、a:hover、a:link,这时候就会发现,不管我有没有hover上去,样式都是link的样式的,这是因为鼠标经过的未访问链接同时拥有a:link、a:hover两种属性,在第一种情况下,a:link离它最近,所以它优先满足a:link,而放弃a:hover的重复定义。 
 所以,如果一个链接没有被访问过,那么它有可能同时拥有 link , hover 两个属性,不能让 link 写在后面,否则不管 hover 是否,都会显示link的样式;同样的道理,如果一个链接已经被访问过了,那么它有可能同时拥有visited , hover 两个属性,hover 要在 visited 的后面;
如果把hover放在active后面,那么实际你在激活(active)链接的时候就触发了hover伪类,hover在后面覆盖了active的颜色,所以始终无法看到active的颜色 。
其实 link visited 这两个伪类,并不需要顺序关系。(他们两的位置可以交换)
 
所以,我们总结出,要想让一个链接各个阶段都正常呈现样式,正确的顺序是 lvha ;
 
另外 :link 和 a的样式有可能会冲突
  1. #test{
  2. color:yellow;
  3. }
  4. #test:link{
  5. color:red!important;
  6. }
  7. <a href="#" id="test">sss</a>
总结:当 <a> 标签的 href 属性为空的时候,:link样式不会生效,所以正常的  color : yellow 会生效;当 <a> 标签的 href 属性不为空的时候,:link 样式才会生效,这时候,如果 <a> 标签正常样式 和 a:link 冲突了的话,以写在后面的那个为准;
 
 
参考:https://www.cnblogs.com/dujuncheng/p/8a44d12f5dec0def9518321af4e71c22.html

转载于:https://www.cnblogs.com/1833lljy/p/10757377.html

你可能感兴趣的文章
Html5新增加的属性
查看>>
php生成图片缩略图,支持png透明
查看>>
Django——模板层(template)(模板语法、自定义模板过滤器及标签、模板继承)
查看>>
论一个蒟蒻的脑子里可以有多少坑(貌似咕了……目前更新保持在noip阶段)
查看>>
Python第三方库安装和卸载zz
查看>>
C++——虚函数表解析
查看>>
重磅!共享单车漏洞独家发布。
查看>>
html中特殊符号
查看>>
为什么 SharedPreferences 可以直接 调用,前面却没有对象
查看>>
php fsockopen 中多线程的解决办法
查看>>
yii框架后台过滤器的使用 安全防护
查看>>
[nginx]lua操作redis
查看>>
第四章 串和数组 (主要kmp算法)
查看>>
laravel 把对象换为数组以及 foreach循环遍历
查看>>
mongodb的docker化安装
查看>>
R笔记
查看>>
【数据结构-ZZU】01. 绪论
查看>>
剑指offer——面试题23:链表中环的入口节点
查看>>
X-Frame-Options,X-XSS-Protection,X-Content-Type-Options
查看>>
iOS下的多种字符串加密方式
查看>>