利用CSS3的定位页面元素


Posted in HTML / CSS onAugust 29, 2009

虽然我们已经使用CSS2.1选择器排除掉了所有的class和id,显然还会有很多更复杂的情况需要CSS3的高级选择器来解决。让我们通过完成一下的实例来了解一下如何在不使用无用的class和id属性的情况下利用CSS3定位页面元素。
相关下载:CSS3.0参考手册下载
使用一个唯一的日志(post)ID定位所有日志

wordpress提供给我们一种包含了ID的每篇日志的源代码输出。这种信息通常用于导航和/或了解资料的意图,不过CSS3可以利用这些唯一的ID来定义这些日志的样式。当然,你还可以像往常那样为每篇日志添加class=”post”这样的属性,但这就与我们练习的意图相冲突了(再加上它没有一点乐趣所在)。使用”子字符串匹配选择器”,我们就可以像下面这样定位所有日志和它们的不同元素了。

article[id*=post-] {} /* 定位所有日志 */
article[id*=post-] header h1 {} /* 定位所有日志中的h1标签 */
article[id*=post-] section p {} /* 定位所有日志中的p标签 */
我没仍然可以使用同样的方式定位评论的元素和它们的子元素。

article[id*=comment-] {} /* 定位所有评论 */
article[id*=comment-] header h1 {} /* 定位所有评论中的h1标签 */
article[id*=comment-] section p {} /* 定位所有评论中的p标签 */
定位一些指定的区域(section)或文章(article)

有很多博客的日志量和评论量都相当大,HTML 5 会将它们由<section>或<article>元素组成。为了定位哪些指定的<section>或<article>元素,我们就要转而使用强大的“:nth-child”选择器了:

section:nth-child(1) {} /* 选择第一个 <section> */
article:nth-child(1) {} /* 选择第一个 <article> */
section:nth-child(2) {} /* 选择第二个 <section> */
article:nth-child(2) {} /* 选择第二个 <article> */
同样,我们可以使用“:nth-last-child”选择器定位反序的一些元素。

section:nth-last-child(1) {} /* 选择最后一个 <section> */
article:nth-last-child(1) {} /* 选择最后一个 <article> */
section:nth-last-child(2) {} /* 选择倒数第二个 <section> */
article:nth-last-child(2) {} /* 选择倒数第二个 <article> */
使用更多的方式选择指定元素

另一种选择HTML5中指定元素(如header、section和footer)的方法就是利用”:only-of-type”选择器的优势。由于这些HTML5元素通常会在很多地方出现不止一次,所以当我们想定位那种在父元素下仅出现过一次的标签时这种方法很方便。例如,我们要选择的是在某元素中有切仅有的唯一一个元素,如以下代码:

复制代码
代码如下:

<section>
<section></section>
<section>
<section>定位这个section元素</section>
</section>
<section>
<section>定位这个section元素</section>
</section>
<section>
<section>但不定位这个section元素</section>
<section>和这个section元素</section>
</section>
<section></section>
</section>

我们可以仅使用以下一行选择器:
section>section:only-of-type {}

再次唠叨,你可以固执的为每个元素添加ID属性,但你会失去代码的可扩展性、维护性和绝对简洁的结构与表现相分离。CSS3的确能让我们可快速更方便的定位几乎所有没有ID和class属性的页面元素。

HTML / CSS 相关文章推荐
CSS3实现粒子旋转伸缩加载动画
Apr 22 HTML / CSS
纯HTML5+CSS3制作图片旋转
Jan 12 HTML / CSS
简单总结CSS3中视窗单位Viewport的常见用法
Feb 04 HTML / CSS
基于CSS3实现立方体自转效果
Mar 01 HTML / CSS
基于CSS3 animation动画属性实现轮播图效果
Sep 12 HTML / CSS
HTML5 本地存储和内容按需加载的思路和方法
Apr 07 HTML / CSS
一波HTML5 Canvas基础绘图实例代码集合
Feb 28 HTML / CSS
HTML5+CSS3绘制锯齿状的矩形
Mar 01 HTML / CSS
谈一谈HTML5本地存储技术
Mar 02 HTML / CSS
Canvas制作旋转的太极的示例
Mar 09 HTML / CSS
Html5适配iphoneX刘海屏的简单实现
Apr 09 HTML / CSS
纯CSS打字动画的实现示例
Aug 05 HTML / CSS
CSS3属性使网站设计增强同时不消弱可用性
Aug 29 #HTML / CSS
HTML5和CSS3让网页设计提升到下一个高度
Aug 14 #HTML / CSS
用CSS3将你的设计带入下个高度
Aug 08 #HTML / CSS
CSS3 优势以及网页设计师如何使用CSS3技术
Jul 29 #HTML / CSS
CSS3 优势以及网页设计师如何使用CSS3技术
Jul 29 #HTML / CSS
HTML5 CSS3给网站设计带来出色效果
Jul 16 #HTML / CSS
CSS3 圆角效果
Jul 15 #HTML / CSS
You might like
php利用云片网实现短信验证码功能的示例代码
2017/11/18 PHP
PHP绕过open_basedir限制操作文件的方法
2018/06/10 PHP
JS的反射问题
2010/04/07 Javascript
jQuery ajax cache缓存问题
2010/07/01 Javascript
js 限制数字 js限制输入实现代码
2012/12/04 Javascript
js中replace的用法总结
2013/12/27 Javascript
不得不分享的JavaScript常用方法函数集(上)
2015/12/23 Javascript
js字符串引用的两种方式(必看)
2016/09/18 Javascript
BootStrapTable服务器分页实例解析
2016/12/20 Javascript
vue-cli的eslint相关用法
2017/09/29 Javascript
对angular2中的ngfor和ngif指令嵌套实例讲解
2018/09/12 Javascript
微信小程序去除左上角返回键的实现方法
2020/03/06 Javascript
解决vue里a标签值解析变量,跳转页面,前面加默认域名端口的问题
2020/07/22 Javascript
Vue使用轮询定时发送请求代码
2020/08/10 Javascript
[02:50]2014DOTA2 TI预选赛预选赛 大神专访第一弹!
2014/05/21 DOTA
python定时执行指定函数的方法
2015/05/27 Python
深入学习Python中的上下文管理器与else块
2017/08/27 Python
Python聊天室程序(基础版)
2018/04/01 Python
Python对CSV、Excel、txt、dat文件的处理
2018/09/18 Python
python 函数内部修改外部变量的方法
2018/12/18 Python
Python 支付整合开发包的实现
2019/01/23 Python
安装pyecharts1.8.0版本后导入pyecharts模块绘图时报错: “所有图表类型将在 v1.9.0 版本开始强制使用 ChartItem 进行数据项配置 ”的解决方法
2020/08/18 Python
详解Python 函数参数的拆解
2020/09/02 Python
Python实现快速大文件比较代码解析
2020/09/04 Python
如何一键升级Python所有包
2020/11/05 Python
New Balance比利时官方网站:购买鞋子和服装
2021/01/15 全球购物
俄罗斯运动、健康和美容产品在线商店:Lactomin.ru
2020/07/23 全球购物
如何强制垃圾回收
2015/10/06 面试题
上班玩游戏检讨书
2014/02/07 职场文书
银行职员个人的工作自我评价
2014/02/15 职场文书
《鱼游到了纸上》教学反思
2014/02/20 职场文书
生日宴会策划方案
2014/06/03 职场文书
联谊活动总结
2014/08/28 职场文书
幼儿园老师新年寄语2015
2014/12/08 职场文书
保管员岗位职责
2015/02/14 职场文书
Python测试框架pytest高阶用法全面详解
2022/06/01 Python