CSS3 伪类选择器 nth-child()说明


Posted in HTML / CSS onJuly 10, 2010

CSS3的强大,让人惊叹,人们在惊喜之余,又不得不为其艰难的道路感到可惜:好的标准只有得到行业浏览器的良好支持才算得上“标准”。CSS3标准已提出数年,但是目前能实现她的浏览器并不多,虽然部分浏览器能实现部分规范,但这又有什么用呢?面对更多的兼容性问题,CSSer们只有望洋轻叹。虽然如此,但有前瞻性的我们,又怎能停步不前呢?今天我们就来“前瞻”一下CSS3的一个伪类选择器“:nth-child()”

语法:

:nth-child(an+b)

为什么选择她,因为我认为,这个选择器是最多学问的一个了。很可惜,据我所测,目前能较好地支持她的只有Opera9+和Safari3+。

描述:

伪类:nth-child()的参数是an+b,如果按照w3.org上的描述,写成中文,很可能会让人头晕,再加上笔者的文笔水平有限,所以我决定避开an+b的说法,把它拆分成5种写法共5部分来说明。

第一种:简单数字序号写法

:nth-child(number)

直接匹配第number个元素。参数number必须为大于0的整数。

例子:

li:nth-child(3){background:orange;}/*把第3个LI的背景设为橙色*/

第二种:倍数写法

:nth-child(an)

匹配所有倍数为a的元素。其中参数an中的字母n不可缺省,它是倍数写法的标志,如3n、5n。

例子:

li:nth-child(3n){background:orange;}/*把第3、第6、第9、…、所有3的倍数的LI的背景设为橙色*/

第三种:倍数分组匹配

:nth-child(an+b) 与 :nth-child(an-b)

先对元素进行分组,每组有a个,b为组内成员的序号,其中字母n和加号+不可缺省,位置不可调换,这是该写法的标志,其中a,b均为正整数或0。如3n+1、5n+1。但加号可以变为负号,此时匹配组内的第a-b个。(其实an前面也可以是负号,但留给下一部分讲。)

例子:

li:nth-child(3n+1){background:orange;}/*匹配第1、第4、第7、…、每3个为一组的第1个LI*/

li:nth-child(3n+5){background:orange;}/*匹配第5、第8、第11、…、从第5个开始每3个为一组的第1个LI*/

li:nth-child(5n-1){background:orange;}/*匹配第5-1=4、第10-1=9、…、第5的倍数减1个LI*/

li:nth-child(3n±0){background:orange;}/*相当于(3n)*/

li:nth-child(±0n+3){background:orange;}/*相当于(3)*/

第四种:反向倍数分组匹配

:nth-child(-an+b)

此处一负一正,均不可缺省,否则无意义。这时与:nth-child(an+1)相似,都是匹配第1个,但不同的是它是倒着算的,从第b个开始往回算,所以它所匹配的最多也不会超过b个。

例子:

li:nth-child(-3n+8){background:orange;}/*匹配第8、第5和第2个LI*/

li:nth-child(-1n+8){background:orange;}/*或(-n+8),匹配前8个(包括第8个)LI,这个较为实用点,用来限定前面N个匹配常会用到*/

第五种:奇偶匹配

:nth-child(odd) 与 :nth-child(even)

分别匹配序号为奇数与偶数的元素。奇数(odd)与(2n+1)结果一样;偶数(even)与(2n+0)及(2n)结果一样。

附:例子效果图

CSS3 伪类选择器 nth-child()说明

HTML / CSS 相关文章推荐
CSS实现鼠标滑过鼠标点击代码写法
Dec 26 HTML / CSS
css3气泡 css3关键帧动画创建的动态通知气泡
Feb 26 HTML / CSS
css 元素选择器的简单实例
May 23 HTML / CSS
一篇文章带你学习CSS3图片边框
Nov 04 HTML / CSS
Html5内唤醒百度、高德APP的实现示例
May 20 HTML / CSS
关于HTML5你必须知道的28个新特性,新技巧以及新技术
May 28 HTML / CSS
css 如何让背景图片拉伸填充避免重复显示
Jul 11 HTML / CSS
html5定位并在百度地图上显示的示例
Apr 27 HTML / CSS
html5页面结构_动力节点Java学院整理
Jul 10 HTML / CSS
解决HTML5中的audio在手机端和微信端的不能自动播放问题
Nov 04 HTML / CSS
使用iframe+postMessage实现页面跨域通信的示例代码
Jan 14 HTML / CSS
HTML5拖拽文件上传的示例代码
Mar 04 HTML / CSS
css3 border-image使用说明
Jun 23 #HTML / CSS
HTML+CSS3 模仿Windows7 桌面效果
Jun 17 #HTML / CSS
基于css3仿造window7的开始菜单
Jun 17 #HTML / CSS
css3.0新属性效果在ie下的解决方案
May 10 #HTML / CSS
CSS3 开发工具收集
Apr 17 #HTML / CSS
收集的7个CSS3代码生成工具
Apr 17 #HTML / CSS
各大浏览器 CSS3 和 HTML5 兼容速查表 图文
Apr 01 #HTML / CSS
You might like
PHP 创建文件(文件夹)以及目录操作代码
2010/03/04 PHP
如何用PHP实现插入排序?
2013/04/10 PHP
Laravel框架基于中间件实现禁止未登录用户访问页面功能示例
2019/01/17 PHP
PHP保存Base64图片base64_decode的问题整理
2019/11/04 PHP
对google个性主页的拖拽效果的js的完整注释[转]
2007/04/10 Javascript
JavaScript 学习笔记(九)call和apply方法
2010/01/11 Javascript
JavaScript中读取和保存文件实例
2014/05/08 Javascript
深入理解setTimeout函数和setInterval函数
2016/05/20 Javascript
JS只能输入正整数的简单实例
2016/10/07 Javascript
JS限制条件补全问题实例分析
2016/12/16 Javascript
微信小程序中顶部导航栏的实现代码
2017/03/30 Javascript
bootstrap中selectpicker下拉框使用方法实例
2018/03/22 Javascript
TypeScript类型声明书写详解
2019/08/28 Javascript
react实现移动端下拉菜单的示例代码
2020/01/16 Javascript
html中创建并调用vue组件的几种方法汇总
2020/11/17 Javascript
python通过yield实现数组全排列的方法
2015/03/18 Python
Python之dict(或对象)与json之间的互相转化实例
2018/06/05 Python
用python写一个定时提醒程序的实现代码
2019/07/22 Python
numpy np.newaxis 的实用分享
2019/11/30 Python
检测tensorflow是否使用gpu进行计算的方式
2020/02/03 Python
Python sorted对list和dict排序
2020/06/09 Python
Python如何执行系统命令
2020/09/23 Python
如何基于Python实现word文档重新排版
2020/09/29 Python
印尼最大的网上书店:Gramedia.com
2018/09/13 全球购物
js实现弹框效果
2021/03/24 Javascript
房地产广告词大全
2014/03/19 职场文书
社区工作者演讲稿
2014/05/23 职场文书
领导班子四风表现材料
2014/08/23 职场文书
公司领导九九重阳节发言稿2014
2014/09/25 职场文书
升学宴答谢词
2015/01/05 职场文书
物业保洁员管理制度
2015/08/05 职场文书
运动会主持人开幕词
2016/03/04 职场文书
MongoDB使用profile分析慢查询的步骤
2021/04/30 MongoDB
java objectUtils 使用可能会出现的问题
2022/02/28 Java/Android
关于mysql中string和number的转换问题
2022/06/14 MySQL
MySQL索引失效场景及解决方案
2022/07/23 MySQL