- 做者:陈大鱼头
- github: KRISACHAN
在上一篇【Hello CSS】
的序章CSS起源中介绍了CSS
的诞生缘由以及发展历史,了解了CSS
的存在乎义。从正篇篇开始将会正式开始介绍CSS
这门语言的特色与功能。本篇则主要介绍CSS
的语法与CSS
是如何工做的。css
CSS
规则主要由两部分组成:选择器(selector)
与声明(declarations)
。html
选择器(selector)
是开发者但愿改变样式的HTML
元素。html5
声明(declarations)
则是开发者制定的但愿HTML
改变的元素规则,能够是一条或多条。git
每条声明(declarations)
由一个属性(property)
和一个值(value)
组成。github
属性(property)
是开发者但愿设置的样式属性(style attribute)
。api
值(value)
为属性的具体内容。浏览器
属性与值之间由冒号
隔开,声明与声明直接由分号
隔开。微信
CSS中的注释以 /*
开始并以 */
结束。dom
/* selector {property: value} */
h1 {color:red; font-size:14px;}
复制代码
上面这行代码的做用是将 h1 元素内的文字颜色定义为红色,同时将字体大小设置为 14 像素。ide
这是基本规则,具体规则请看CSS 基础语法。
每一个HTML元素都有初始的样式,可是也能够通过开发者书写而改变样式规则。
HTML
的元素样式修改有如下的书写规则。
<head>
标签内部)<!DOCTYPE html>
<html>
<head>
<style> h1 {color:red; font-size:14px;} </style>
</head>
<body>
</body>
</html>
复制代码
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<h1 style="color:red; font-size:14px;"></h1>
</body>
</html>
复制代码
<!-- style.css -->
h1 {color:red; font-size:14px;}
<!-- index.html -->
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="style.css">
</head>
<body>
<h1></h1>
</body>
</html>
复制代码
一个at-rule就是一个CSS语句,以
@
开头,后接标识符
,最后以;
结束。
@charset
用于定义样式表中使用的字符编码。它必须写在样式表的最开头且前面不可有别的字符。
/* @charset "<charset>"; */
@charset "UTF-8";
复制代码
@import
用于导入外部CSS样式表
文件。
/* @import url; */
/* @import url list-of-media-queries; */
@import 'custom.css';
@import url("fineprint.css") print;
复制代码
@namespace
是用来定义使用在CSS样式表
中的XML
命名空间的@规则。
/* @namespace <namespace-prefix>? [ <string> | <url> ]; */
@namespace url(http://www.w3.org/1999/xhtml);
@namespace svg url(http://www.w3.org/2000/svg);
复制代码
@media
用于定义在一个或多个设备类型、具体特色和环境的媒体查询来应用样式。
/* @media */
@media screen and (min-width: 900px) {
h1 {
color:red;
font-size:14px;
}
}
复制代码
@page
用于在打印文档时修改某些CSS属性。@page
规则只能修改margin
、orphans
、widow
和 page breaks of the document
,对其余属性的修改是无效的。
/* * @page <page-selector-list> { * <page-body> * } */
@page {
size: 10in 20in;
margin: 10% 20%;
}
复制代码
@keyframs
经过定义动画序列中的关键帧来控制CSS动画
不一样步骤的状态。
/* @keyframes */
@keyframes slidein {
from {
margin-left: 100%;
width: 300%;
}
to {
margin-left: 0%;
width: 100%;
}
}
复制代码
@supports
用来检测规则组的规则是否生效。规则与@media
相似
/* * @supports <supports_condition> { * <specific rules> * } */
@supports (display: flex) {
div {
display: flex;
}
}
复制代码
@viewport
用于设置视口(viewport)
的特性。
/* * @viewport { * <group-rule-body> * } */
@viewport {
min-width: 640px;
max-width: 800px;
}
@viewport {
zoom: 0.75;
min-zoom: 0.5;
max-zoom: 0.9;
}
@viewport {
orientation: landscape;
}
复制代码
@counter-style
用于自定义counter
的样式
/* * @counter-style <counter-style-name> { * <group-rule-body> * } */
@counter-style circled-alpha {
system: fixed;
symbols: Ⓐ Ⓑ Ⓒ Ⓓ Ⓔ Ⓕ Ⓖ Ⓗ Ⓘ Ⓙ Ⓚ Ⓛ Ⓜ Ⓝ Ⓞ Ⓟ Ⓠ Ⓡ Ⓢ Ⓣ Ⓤ Ⓥ Ⓦ Ⓧ Ⓨ Ⓩ;
suffix: " ";
}
.items {
list-style: circled-alpha;
}
复制代码
@font-face
用于给网页指定文本字体。
/* * @font-face { * <group-rule-body> * } */
@font-face {
font-family: "Bitstream Vera Serif Bold";
src: url("http://developer.mozilla.org/@api/deki/files/2934/=VeraSeBd.ttf");
}
body { font-family: "Bitstream Vera Serif Bold", serif }
复制代码
@document
若是知足条件组的条件,则规则生效(推延至 CSS Level 4 规范)
/* * @document name(guide) { * <group-rule-body> * } */
@document url(http://www.w3.org/),
url-prefix(http://www.w3.org/Style/),
domain(mozilla.org),
regexp("https:.*") {
/* 该条CSS规则会应用在下面的网页: + URL为"http://www.w3.org/"的页面. + 任何URL以"http://www.w3.org/Style/"开头的网页 + 任何主机名为"mozilla.org"或者主机名以".mozilla.org"结尾的网页 + 任何URL以"https:"开头的网页 */
/* make the above-mentioned pages really ugly */
body {
color: purple;
background: yellow;
}
}
复制代码
注:上面的@规则属性并不是完整,还有少许相关的没有列出,须要详细列表的能够翻阅MDN
在讲CSS
的工做流程以前,首先来简单看看页面的渲染机制。
页面渲染可分为下面5个步骤:
HTML
来建立DOM tree
;CSS
来建立CSSOM tree;
DOM
跟CSSOM
来合并render tree;
render tree
来布局;render tree
。以上即是页面渲染的过程。
从上面的页面渲染流程能够知道浏览器在解析了HTML
跟CSS
以后便开始合并渲染,简单来讲就是绘制带有样式的HTML
规则。
CSS
的工做流程就是把CSS
规则定义到DOM tree
上。
HTML
与CSS
具体解析规则属于编译原理
的内容,在这里就不做展开了。可是有在CSS
工做的过程当中有两个词值得注意的就是重排(reflow)跟重绘(repaint)。
render tree
的从新构建叫重排。也就是当页面布局或者DOM
元素的几何属性发生变化时,就会发生浏览器重排。如下5种状况便会引起浏览器回流:
DOM
元素的增删;DOM
元素的位置、尺寸以及引发尺寸变化的内容改变;resize
事件发生时。render tree
中只影响外观而不影响风格的属性改变就叫重绘。例如color
与background-color
的改变。注:后面的文章会仔细讲解重排(reflow)跟重绘(repaint)以及相关的性能问题与优化。
【Hello CSS】
是以CSS
基础概念为主题的系列文章,旨在帮助你们更深入地了解而且提升CSS
在各位开发者心目中的地位。因为鱼头我水平有限,文笔有限,若是各位在文章中发现有任何不合理,不正确的地方,还烦不吝指出,我会很是感谢的;若是经过文章有任何想法或疑问,也但愿各位能积极留言,咱们互相探讨;若是经过本系列文章有所收获,这就让鱼头我喜不自胜了!