child伪类选择符入门(2)
2016-07-19 20:14
302 查看
前面一篇博客介绍了first-child和last-child两个child伪类选择符,现在再介绍only-child选择符,在W3C的说明中,E:only-child{ sRules }是匹配父元素仅有的一个子元素E。
也就是说,这个选择符会匹配有且只有一个E元素作为子元素的父元素的E元素。有点绕,就举个例子吧。
示例1:
HTML代码:
<h1>只有唯一一个子元素</h1>
<ul>
<li>结构性伪类选择符 E:only-child</li>
</ul>
<h1>有多个子元素</h1>
<ul>
<li>结构性伪类选择符 E:only-child</li>
<li>结构性伪类选择符 E:only-child</li>
<li>结构性伪类选择符 E:only-child</li>
</ul>
CSS代码:
只有有且只有一个li元素的被匹配到了,变成了红色,三个li元素的则没有变化。
只有一个子元素,且不能有其余任何元素的情况下才能被匹配。例如对HTML代码稍作修改:
示例2:
HTML代码:
<h1>只有唯一一个子元素</h1>
<ul>
<li>结构性伪类选择符 E:only-child</li>
<p>我是一个p</p>
</ul>
<h1>有多个子元素</h1>
<ul>
<li>结构性伪类选择符 E:only-child</li>
<li>结构性伪类选择符 E:only-child</li>
<li>结构性伪类选择符 E:only-child</li>
</ul>
结果:
只是在有且只有一个li元素的位置加了一个P元素,则就匹配不成功了。
所以这个选择符算是一个比较鸡肋的选择符,只有在某些非常特殊的情况下才会使用到。如果用到了后期修改可能也会造成很多的麻烦,在此不建议使用。
也就是说,这个选择符会匹配有且只有一个E元素作为子元素的父元素的E元素。有点绕,就举个例子吧。
示例1:
HTML代码:
<h1>只有唯一一个子元素</h1>
<ul>
<li>结构性伪类选择符 E:only-child</li>
</ul>
<h1>有多个子元素</h1>
<ul>
<li>结构性伪类选择符 E:only-child</li>
<li>结构性伪类选择符 E:only-child</li>
<li>结构性伪类选择符 E:only-child</li>
</ul>
CSS代码:
h1 { font-size: 16px; } li:only-child { color: #f00; }结果:
只有有且只有一个li元素的被匹配到了,变成了红色,三个li元素的则没有变化。
只有一个子元素,且不能有其余任何元素的情况下才能被匹配。例如对HTML代码稍作修改:
示例2:
HTML代码:
<h1>只有唯一一个子元素</h1>
<ul>
<li>结构性伪类选择符 E:only-child</li>
<p>我是一个p</p>
</ul>
<h1>有多个子元素</h1>
<ul>
<li>结构性伪类选择符 E:only-child</li>
<li>结构性伪类选择符 E:only-child</li>
<li>结构性伪类选择符 E:only-child</li>
</ul>
结果:
只是在有且只有一个li元素的位置加了一个P元素,则就匹配不成功了。
所以这个选择符算是一个比较鸡肋的选择符,只有在某些非常特殊的情况下才会使用到。如果用到了后期修改可能也会造成很多的麻烦,在此不建议使用。
相关文章推荐
- Android Native 绘图方法
- CSS3属性教程与案例分享
- W3C api 抓取
- 在Windows 8.1的IE 11中屏蔽双击放大功能
- HTML5调用摄像头实例
- Powershell 创建炫丽美观的Html报表
- Apple官网研究之使用Justify布局导航
- 关于前端的思考与感悟
- 又被事件冒泡坑了一把,这次要彻底弄懂浏览器的事件流
- 移动端点击事件全攻略,这里的坑你知多少?
- $q 实例分析 Angular 中的 Promise
- Angular directive 实例详解
- 关于浮动与清除浮动,你应该知道的
- 通过Mootools 1.2来操纵HTML DOM元素
- jQuery Html控件基本操作(日常收集整理)
- WEB标准网页布局中尽量不要使用的HTML标签
- Flash 与 html 的一些实用技巧
- html工作中表格<tbody>标签的使用技巧