:nth-child深度解析以及如何实现css奇偶选择器

2017-01-14 10:39:28

官方解释:p:nth-child(2) 选择属于其父元素的第二个子元素的每个 <p> 元素。

    我是表示很难理解。

    应该理解为,p元素的父元素下面的第二个p元素。

    no,不对!看下面的例子吧。

<style>
    p:nth-child(2){
        background: blue;
    }
</style>
<div class="parent">
    <p>第1行P元素</p>
    <p>第2行P元素</p>
    <p>第3行P元素</p>
    <p>第4行P元素</p>
    <p>第5行P元素</p>
    <p>第6行P元素</p>
    <p>第7行P元素</p>
</div>

    效果如下图

blob.png


貌似上面那个观点是正确的。看下面的代码,把p元素前面加一个span标签。

<div class="parent">
    <span>我只是一个span元素</span>
    <p>第1行P元素</p>
    <p>第2行P元素</p>
    <p>第3行P元素</p>
    <p>第4行P元素</p>
    <p>第5行P元素</p>
    <p>第6行P元素</p>
    <p>第7行P元素</p>
</div>

效果如下图

blob.png

显然和我们想的不一样,p:child(2)的意思应该是p标签父元素的地二个孩子。

我可一欣然的告诉你这个想法也不对的。继续看下面,我把span标签放到第一个p标签后面。

<div class="parent">
    <p>第1行P元素</p>
    <span>我只是一个span元素</span>
    <p>第2行P元素</p>
    <p>第3行P元素</p>
    <p>第4行P元素</p>
    <p>第5行P元素</p>
    <p>第6行P元素</p>
    <p>第7行P元素</p>
</div>

效果出我们所料,如下图

blob.png

    元素无任何颜色变化。

    我推测,p:nth-child(2)的意思应该是,选择p标签父元素下面第二个元素并且这个元素为p元素。

    大胆尝试,把样式选择器修改一下,变为nth-child(3)


p:nth-child(3){
    background: blue;
}

    效果如下图

blob.png

看来结论正确:

    p:nth-child(2)的意思应该是,选择p标签父元素下面第二个元素并且这个元素为p元素。


Odd 和 even 是可用于匹配下标是奇数或偶数的子元素的关键词(第一个子元素的下标是 1)。

    我们修改上面的style

p:nth-child(odd){
    background: blue;
}
p:nth-child(even){
    background: yellow;
}

    效果如下图

blob.png

    从图中也可看出span元素并没有被选择,但是它依旧在队列的顺序当中,只是并没有被选择。

    

使用公式 nth:child(an + b)。描述:表示周期的长度,n 是计数器(从 0 开始),b 是偏移值。

上面这个公式可以做出某些不规则的选择

咱们继续修改style

p:nth-child(3n+0){
background:#ff0000;
}

效果如下图

    

blob.png

你可以随意修改a,n, b进行尝试。

  • 2021-02-03 16:47:05

    use_framework头文件不提示

    1、之前没有用use_frameworks!添加swift库,其他库引用使用#import <xxxx.h> 2、使用use_frameworks!添加swift库后,其他库引用使用#import "xxxx.h"

  • 2021-02-03 16:52:27

    ios静态库和动态库区别

    Framework 是 Cocoa/Cocoa Touch 程序中使用的一种资源打包方式,可以将代码文件、头文件、资源文件(nib/xib、图片、国际化文本)、说明文档等集中在一起,方便开发者使用。Framework 其实是资源打包的方式,和静态库动态库的本质是没有什么关系。

  • 2021-02-03 16:57:34

    iOS中的动态库和静态库分析

    由于最近研究组件化后调试时二进制映射源码的功能,发现需要对开发中的动态库和静态库需要有一些了解。所以就有了这篇文章,由于只是了解,并没有深入到编译层面,所以本篇文章只是简单了解一些库的知识,并不深入。

  • 2021-02-03 16:58:39

    iOS静态库与动态库的区别与打包

    这篇主要是记录一下 iOS 下静态库与动态库的打包流程,以便以后用到时快速查阅,供自己也供大家学习记录。同时也简述了一下 动态库 与 静态库 的区别。

  • 2021-02-03 16:59:59

    iOS 静态库和动态库全分析

    库就是程序代码的集合,将 N 个文件组织起来,是共享程序代码的一种方式。从本质上来说是一种可执行代码的二进制格式,可以被载入内存中执行。

  • 2021-02-03 17:01:30

    iOS库 .a与.framework区别

    静态库:连接时完整地拷贝至可执行文件中,被屡次使用就有多份冗余拷贝。 动态库:连接时不复制,程序运行时由系统动态加载到内存,供程序调用,系统只加载一次,多个程序共用,节省内存。

  • 2021-02-03 17:13:58

    iOS - 封装静态库

    静态库:链接时完整的拷贝至可执行文件中,被多次使用就有多份冗余拷贝,.a的静态库 .framework的静态库

  • 2021-02-03 17:16:07

    iOS 中的动态库、静态库和 framework

    首先来看什么是库,库(Library)说白了就是一段编译好的二进制代码,加上头文件就可以供别人使用。 什么时候我们会用到库呢?一种情况是某些代码需要给别人使用,但是我们不希望别人看到源码,就需要以库的形式进行封装,只暴露出头文件。另外一种情况是,对于某些不会进行大的改动的代码,我们想减少编译的时间,就可以把它打包成库,因为库是已经编译好的二进制了,编译的时候只需要 Link 一下,不会浪费编译时间。