: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进行尝试。

  • 2017-04-15 21:47:44

    Android开发笔记——圆角和边框们

    在做Android界面开发时,我们往往希望它尽可能优美,尽可能显得专业。于是你看了看其他应用,哇,好多边框和圆角啊。你是不是也想给自己的应用加上边框和圆角效果?呃……那怎么做呢?如果你是从web前端跑到Android来的,那么我想你一定想到了不下三种解决方案。如用图片替代,用CSS3定义,用JS画。在Android中,其实也有类似的用法,本文将简单介绍两种Android圆角和边框的实现。

  • 2017-04-15 21:49:06

    Android样式的开发:Style篇

    前面铺垫了那么多,终于要讲到本系列的终篇,整合所有资源,定义成统一的样式。 哪些该定义成统一的样式呢?举几个例子吧:

  • 2017-04-15 23:54:49

    ViewPager+Fragment取消预加载以及禁止滑动

    取消预加载 网上了解了很多取消预加载的方法,里面提到了使用一个viewpager的public方法setOffscreenPageLimit 经过查看源码以及验证发现该方法是管理Viewpager预加载的页数,最低也是默认为一页(例如ViewPager一共有4页,当前手机屏幕显示第一页

  • 2017-04-15 23:56:30

    onInterceptTouchEvent和onTouchEvent调用关系详解

    如果没有onInterceptTouchEvent,只考虑onTouchEvent的话,比较容易分析和理解。假如有三层布局结构,linearLayout1,linearLayout2,textView,从前到后是包含的关系。那么下面分情况说明。

  • 2017-04-16 19:36:32

    ViewPager预加载问题和onCreateView多次调用问题的解决

    1,在使用ViewPager嵌套Fragment的时候,由于VIewPager的几个Adapter的设置来说,都会有一定的预加载(默认是左右各一个Frament)。通过设置setOffscreenPageLimit(int number) 来设置预加载的熟练,在V4包中,默认的预加载是1,即使你设置为0,也是不起作用的,设置的只能是大于1才会有效果的。我们需要通过更改V4包中的默认属性才可以

  • 2017-04-16 21:02:55

    ImageView的android:adjustViewBounds属性

    取值为true时: Adjust the ImageView's bounds to preserve the aspect ration of its drawable. 调整ImageView的界限来保持图像纵横比不变。 这并不意味着ImageView的纵横比就一定和图像的纵横比相同