利用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的方法
Aug 29 HTML / CSS
CSS的background属性及CSS3的背景图片设置总结
Jun 13 HTML / CSS
详解CSS3浏览器兼容
Dec 14 HTML / CSS
HTML5+CSS3 实现灵动的动画 TAB 切换效果(DEMO)
Sep 15 HTML / CSS
CSS3实现div从下往上滑入滑出效果示例
Apr 28 HTML / CSS
css3中flex布局宽度不生效的解决
Dec 09 HTML / CSS
HTML5离线缓存Manifest是什么
Mar 09 HTML / CSS
html通过canvas转成base64的方法
Jul 18 HTML / CSS
HTML5 通信API 跨域门槛将不再高、数据推送也不再是梦
Apr 25 HTML / CSS
HTML5 video 事件应用示例
Sep 11 HTML / CSS
AmazeUI中模态框的实现
Aug 19 HTML / CSS
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
Apr 29 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 access 数据连接与读取保存编辑数据的实现代码
2010/05/12 PHP
ThinkPHP访问不存在的模块跳转到404页面的方法
2014/06/19 PHP
jQuery获取样式中的背景颜色属性值/颜色值
2012/12/17 Javascript
jQuery动态地获取系统时间实现代码
2013/05/24 Javascript
jquery 面包屑导航 具体实现
2013/06/05 Javascript
JS页面延迟执行一些方法(整理)
2013/11/11 Javascript
js如何获取object类型里的键值
2014/02/18 Javascript
javascript使用输出语句实现网页特效代码
2015/08/06 Javascript
JavaScript 节流函数 Throttle 详解
2016/07/04 Javascript
Bootstrap基本样式学习笔记之表格(2)
2016/12/07 Javascript
node.js实现复制文本到剪切板的功能
2017/01/23 Javascript
canvas实现十二星座星空图
2017/02/14 Javascript
ligerUI---ListBox(列表框可移动的实例)
2017/11/28 Javascript
js实现弹出框的拖拽效果实例代码详解
2019/04/16 Javascript
使用element-ui的el-menu导航选中后刷新页面保持当前选中状态
2019/07/19 Javascript
详解Vue之事件处理
2020/07/10 Javascript
vue表单验证之禁止input输入框输入空格
2020/12/03 Vue.js
python中threading超线程用法实例分析
2015/05/16 Python
Python 数据结构之队列的实现
2017/01/22 Python
在windows下使用python进行串口通讯的方法
2019/07/02 Python
python Django的web开发实例(入门)
2019/07/31 Python
Python字典中的值为列表或字典的构造实例
2019/12/16 Python
python 双循环遍历list 变量判断代码
2020/05/04 Python
python Selenium 库的使用技巧
2020/10/16 Python
css3.0 图形构成实例练习二
2013/03/19 HTML / CSS
CSS3实现网站商品展示效果图
2020/01/18 HTML / CSS
巧用 CSS3的webkit-box-reflect 倒影实现各类动效
2021/03/05 HTML / CSS
HTML5之WebGL 3D概述(下)—借助类库开发及框架介绍
2013/01/31 HTML / CSS
html5的websockets全双工通信详解学习示例
2014/02/26 HTML / CSS
HTML5打开手机扫码功能及优缺点
2017/11/27 HTML / CSS
美国最大的香水出口:FragranceX.com
2017/11/04 全球购物
澳大利高级泳装品牌:Bondi Born
2018/05/23 全球购物
机械专业个人求职自荐信格式
2013/09/21 职场文书
贸易跟单员英文求职信
2014/04/19 职场文书
公司年会主持词范文!
2019/05/07 职场文书
导游词之西江千户苗寨
2019/12/24 职场文书