导读:

CSS3 中有许多伪类选择器,其中一些伪类选择器的作用近似却又不完全一样,下面我们就来看一看到底有什么不一样。

1、:only-child:only-of-type

      测试的代码:
<div>
<p>something</p>
</div>
<div>
<div>other something</div>
<p>something</p>
</div>
  • :only-child 是指匹配属于父元素中唯一子元素的元素。设置 p:only-child { background-color:#00ff00; } 后表现为:

    something

    other something

    something

  • :only-of-type是指匹配指定元素的父元素中唯一相同类型的子元素(该父元素可以有很多子元素,而与指定匹配的元素属于同一种类型的子元素是唯一的,则为其设定样式)。设置 p:only-of-type { background-color:#00ff00; } 后表现为:

    something

    other something

    something

2、:first-child:first-of-type

      测试的代码:
<div>
<p>something</p>
<div>other something</div>
</div>
<div>
<div>other something</div>
<p>something</p>
</div>
  • :first-child 是指匹配的对象是其所在的父元素的第一个元素。设置 p:first-child { background-color:#00ff00; } 后表现为:

    something

    other something
    other something

    something

  • :first-of-type 是指匹配的对象是其所在的父素的第一个相同类型元素。设置 p:first-of-type { background-color:#00ff00; } 后表现为:

    something

    other something
    other something

    something

3、:last-child:last-of-type 可以参考 :first-child:first-of-type 的思路

4、:nth-child(n):nth-of-type(n)

      测试的代码:
<div>
<div>other something</div>
<p>something</p>
<p>something</p>
<p>something</p>
</div>
  • nth-child(n) 是指匹配的对象是其所在的父元素的第 n 个元素。设置 p:nth-child(n) { background-color:#00ff00; } 后表现为:

    • 当 n 为 1(数字) 时:没有被选中的元素。
    • 当 n 为 2(数字) 时:
      other something

      something

      something

      something

    • 当 n 为 n+3(公式) 时:
      other something

      something

      something

      something

    • 当 n 为 -n+3(公式) 时:
      other something

      something

      something

      something

    • 当 n 为 2n(公式) 时:
      other something

      something

      something

      something

    • 当 n 为 2n+1(公式) 时:
      other something

      something

      something

      something

  • tips:上面中的 n 的取值可以是数字,一个关键字,一个公式(此时 n 是一个从0开始的计数器)。当 n 取值 -n+2 表示小于等于2;当 n 取值 n+2 表示大于等于2;当 n 取值 2n 表示取偶数,也可以用 even 代替;当 n 取值 2n-1 表示去奇数,也可以用 odd 代替。
  • nth-of-type(n) 是指匹配的对象是其所在的父素的第 n 个相同类型元素。设置 p:nth-of-type(n) { background-color:#00ff00; } 后表现为:
    • 当 n 为 1(数字) 时:

      other something

      something

      something

      something

    • 当 n 为 2(数字) 时:
      other something

      something

      something

      something

    • 当 n 为 n+3(公式) 时:
      other something

      something

      something

      something

    • 当 n 为 -n+3(公式) 时:
      other something

      something

      something

      something

    • 当 n 为 2n(公式) 时:
      other something

      something

      something

      something

    • 当 n 为 2n+1(公式) 时:
      other something

      something

      something

      something

5、:nth-last-child(n):nth-last-of-type(n) 可以参考 :nth-child(n):nth-of-type(n) 的思路

若是文中有什么错误,欢迎大家指正批评,愿与大家在问题的交流之中共同进步。愈激烈,愈深刻。

CSS 中功能相似伪类间的区别的更多相关文章

  1. CSS中的一些伪类

    一.:nth-child 和 :nth-of-type (1):nth-child() :nth-child(n) 选择器选取某任意一父元素的第 n 个子元素( p:nth-child(n) 即选中任 ...

  2. 学习css常用基本层级伪类属性选择器

    常见的css选择器包含:常用选择器.基本选择器.层级选择器.伪类选择器.属性选择器,其中常用选择器分为:1.html选择符*{}//给页面上所有的标签设置模式:2.类选择符.hcls{}//给clas ...

  3. 妙味css3课程---1-2、css3中新增的伪类和伪元素有哪些

    妙味css3课程---1-2.css3中新增的伪类和伪元素有哪些 一.总结 一句话总结: 1.div:target{}是什么意思? 比如a标签的锚点链接到div,div:target{}就可以找到这个 ...

  4. css中px,em和rem的区别

    css中px,em和rem的区别 今天,突然间发现一个特别有意思的问题,就是无意间看到一个网站中的em并不是16px,下面展开了对于px和em以及rem的探究. 首先,px是绝对长度单位,是相对于显示 ...

  5. css中word-break、word-wrap和white-space的区别

    css中word-break.word-wrap和white-space的区别 :https://baijiahao.baidu.com/s?id=1578623236521030997&wf ...

  6. 前端笔记之HTML5&CSS3(中)选择器&伪类伪元素&CSS3效果&渐变背景&过渡

    一.CSS3选择器 CSS3是CSS的第三代版本,新增了很多功能,例如:强大的选择器.盒模型.圆角.渐变.动画.2D/3D转换.文字特效等. CSS3和HTML5没有任何关系!HTML5骨架中,可以用 ...

  7. CSS设计指南之伪类

    伪类这个叫法源自它们与类相似,但实际上并没有类会附加到标记中的标签上.伪类分两种. UI伪类会在HTML元素处于某个状态时(比如鼠标指针位于链接上),为该元素应用CSS样式. 结构化伪类会在标记中存在 ...

  8. Html学习之十(CSS选择器的使用--伪类选择器)

    伪类选择器 一.基于a标签. 1.:hover 选择鼠标滑过的超链接元素 2.:active 选择鼠标单击中的超链接元素 3.:link 选择未被访问的超链接元素 4.:visited 选择已经被访问 ...

  9. css 04-CSS选择器:伪类

    04-CSS选择器:伪类 #伪类(伪类选择器) 伪类:同一个标签,根据其不同的种状态,有不同的样式.这就叫做"伪类".伪类用冒号来表示. 比如div是属于box类,这一点很明确,就 ...

随机推荐

  1. Dubbo 系列(07-2)集群容错 - 服务路由

    目录 Dubbo 系列(07-2)集群容错 - 服务路由 1. 背景介绍 1.1 继承体系 1.2 SPI 2. 源码分析 2.1 创建路由规则 2.2 RouteChain 2.3 条件路由 Dub ...

  2. SQL数据库—<7>事务、异常和游标

    事务 一.什么是事务能够保证数据的一致性的代码控制,要么执行提交,要么滚回事务的初始状态 二.事务的四大特性:ACIDA:原子性-------事务不可拆开,要么执行要么回滚无中间状态C:一致性---- ...

  3. 初识PHP变量函数语法

    PHP连接字符串 . <?php '你好,'.'我的亲爱的老师'?> PHP语句结束符 <?php echo "欢迎同学们!"; echo "Welco ...

  4. 2019CCPC网络赛 HDU6705 - path K短路

    题意:给出n个点m条边的有向图,问图上第K短路的长度是多少(这里的路可以经过任何重复点重复边). 解法:解法参考https://blog.csdn.net/Ratina/article/details ...

  5. Java高频经典面试题(第一季)一:自增的分析

    package will01; public class testZiZeng { public static void main(String[] args) { int i = 1; i = i ...

  6. web之请求转发与重定向

    请求转发: 重定向:

  7. CodeForces 隐藏标签

    设置css 记录. 以防忘记.

  8. string,const char*, char*转换之后还是指向同一片内存地址么?

    class Same { public: void reverse(const char* str) { char* A = const_cast<char*>(str); A[] = ' ...

  9. bzoj 3011

    传送门: http://www.lydsy.com/JudgeOnline/problem.php?id=3011 一想到这个第一反应是树形dp,然后10^18 (' '    ) 所以我直接搞了一个 ...

  10. PHP chroot() 函数

    改变根目录: <?php// Change root directorychroot("/path/to/chroot/"); // Get current director ...