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

2017-01-14 10:38:01

官方解释: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进行尝试。

  • 2019-04-30 11:23:36

    elasticsearch和analysis-ik的安装使用

    全文搜索和中文分词主要介绍了两组全文搜索加中文分词方案; TNTSearch+jieba-php这套组合对于博客这类的小项目基本够用了;

  • 2019-04-30 11:42:24

    php7+laravel+coreseek(sphinx)中文搜索初步实现(Linux)

    官网www.coreseek.cn已不能下载,所以需从网上找资源, 注意的一点是,笔者安装coreseek-3.2.14版本后,使用时提示client版本高于server版本的错误, php的sphinx扩展,为使用者,为client;coreseek是系统服务,为server

  • 2019-04-30 13:55:13

    浅谈mysql fulltext全文索引优缺点

    为什么会注意到mysql的fulltext? nima, 还是上次innodb转成tokudb引擎的事,这次alter修改表引擎的时候,提示percona tokudb是不支持fulltext索引的.

  • 2019-04-30 18:56:52

    elasticsearch文档操作

    使用了Elasticsearch提供的一整套强大的REST API,本文继续来看通过这一套API如何完成文档的基本操作。

  • 2019-05-05 14:04:11

    PHP使用CURL模拟POST/GET/PUT/DELETE方式提交数据

    最近因为工作需要,调用网盘接口来上传文件,我用了CURL库, 当然在用CURL库之前必须要在php中启用 cURL 设置 可以通过使用php_info()函数来得到cURL信息,如果看不到cURL信息的话,那么需要设置PHP并开启这个库。在Windows平台下,需要改一改php.ini文件的设置,找到 php_curl.dll,并取消前面的分号注释就行了。

  • 2019-05-07 00:04:04

    Tcpdf不使用css来实现线上合同和签章,图片悬浮

    以前虽然有了解过Tcpdf的用法,但是没有实际的应用过,最近在用tcpdf的时候发现对css支持很有限,使的如果想实现类似html的种种效果都很难,而我这次要做的就是 图片悬浮在文字上方形成类似水印或者盖章的效果。