一.CSS简介
HTML定义了网页的结构,但是只有HTML页面的布局并不美观,可能只是简单的节点元素的排列,为了让网页看起来更好看一些,这里借助了CSS。
CSS,全称叫作Cascading Style Sheets,即层叠样式表。“层叠”是指当在HTML中引用了数个样式文件,并且样式发生冲突时,浏览器能依据层叠顺序处理。“样式”指网页中文字大小、颜色、元素间距、排列等格式。
CSS是目前唯一的网页页面排版样式标准,有了它的帮助,页面才会变得更为美观。
例如:
#head_wrapper.s-ps-islite .s-p-top {
position: absolute;
bottom: 40px;
width: 100%;
height: 181px;
}
就是一个CSS样式。大括号前面是一个CSS选择器,此选择器的意思是首先选中id
为head_wrapper
且class
为s-ps-islite
的节点,然后再选中其内部的class
为s-p-top
的节点。大括号内部写的就是一条条样式规则,例如position
指定了这个元素的布局方式为绝对布局,bottom
指定元素的下边距为40像素,width
指定了宽度为100%占满父元素,height
则指定了元素的高度。也就是说,我们将位置、宽度、高度等样式配置统一写成这样的形式,然后用大括号括起来,接着在开头再加上CSS选择器,这就代表这个样式对CSS选择器选中的元素生效,元素就会根据此样式来展示了。
在网页中,一般会统一定义整个网页的样式规则,并写入CSS文件中(其后缀为css)。在HTML中,只需要用link
标签即可引入写好的CSS文件,这样整个页面就会变得美观、优雅。
二.CSS选择器
我们知道网页由一个个节点组成,CSS选择器会根据不同的节点设置不同的样式规则,那么怎样来定位节点呢?以下面的代码为例:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>This is a Demo</title>
</head>
<body>
<div id="container">
<div class="wrapper">
<h2 class="title">Hello World</h2>
<p class="text">Hello, this is a paragraph.</p>
</div>
</div>
</body>
</html>
在CSS中,我们使用CSS选择器来定位节点。
例如,代码中div
节点的id
为container
,那么就可以表示为#container
,其中#
开头代表选择id
,其后紧跟id
的名称。
另外,如果我们想选择class
为wrapper
的节点,便可以使用.wrapper
,这里以点(.)开头代表选择class(我的记法是:点class,#为number的简称代表id)
,其后紧跟class
的名称。
另外,还有一种选择方式,那就是根据标签名筛选,例如想选择二级标题,直接用h2
即可。这是最常用的3种表示,分别是根据id
、class
、标签名筛选,请牢记它们的写法。
另外,CSS选择器还支持嵌套选择,各个选择器之间加上空格分隔开便可以代表嵌套关系,如#container .wrapper p
则代表先选择id
为container
的节点,然后选中其内部的class
为wrapper
的节点,然后再进一步选中其内部的p
节点。
另外,如果不加空格,则代表并列关系,如#container .wrapper p.text
代表先选择id
为container
的div
节点,然后选中其内部的class
为wrapper
的节点,再进一步选中其内部的class
为text
的p
节点。这就是CSS选择器,其筛选功能还是非常强大的。
另外,CSS选择器还有一些其他语法规则,具体如下表所示(基本选择器的优先级:id > class > 元素)。
选择器 | 例子 | 例子描述 |
---|---|---|
|
| 选择 |
|
| 选择 |
|
| 选择所有节点 |
|
| 选择所有 |
|
| 选择所有 |
|
| 选择 |
|
| 选择父节点为 |
|
| 选择紧接在 |
|
| 选择带有 |
|
| 选择 |
|
| 选择 |
|
| 选择所有未被访问的链接 |
|
| 选择所有已被访问的链接 |
|
| 选择活动链接 |
|
| 选择鼠标指针位于其上的链接 |
|
| 选择获得焦点的 |
|
| 选择每个 |
|
| 选择每个 |
|
| 选择属于父节点的第一个子节点的所有 |
|
| 在每个 |
|
| 在每个 |
|
| 选择带有以 |
|
| 选择前面有 |
|
| 选择其 |
|
| 选择其 |
|
| 选择其 |
|
| 选择属于其父节点的首个 |
|
| 选择属于其父节点的最后 |
|
| 选择属于其父节点唯一的 |
|
| 选择属于其父节点的唯一子节点的所有 |
|
| 选择属于其父节点的第二个子节点的所有 |
|
| 同上,从最后一个子节点开始计数 |
|
| 选择属于其父节点第二个 |
|
| 同上,但是从最后一个子节点开始计数 |
|
| 选择属于其父节点最后一个子节点的所有 |
|
| 选择文档的根节点 |
|
| 选择没有子节点的所有 |
|
| 选择当前活动的 |
|
| 选择每个启用的 |
|
| 选择每个禁用的 |
|
| 选择每个被选中的 |
|
| 选择非 |
|
| 选择被用户选取的节点部分 |
这篇css选择器主要是用来python爬虫,如果需要写前端的同学,可以查看这篇文章:CSS 常用的几种选择器