栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

第一章-CSS的语法与工作流

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

第一章-CSS的语法与工作流

在上一篇【Hello CSS】的序章CSS起源中介绍了CSS的诞生原因以及发展历史,了解了CSS的存在意义。从正篇篇开始将会正式开始介绍CSS这门语言的特点与功能。本篇则主要介绍CSS的语法与CSS是如何工作的。

CSS语法1. 基本规则

CSS规则主要由两部分组成:选择器(selector)与声明(declarations)。

选择器(selector)是开发者希望改变样式的HTML元素。

声明(declarations)则是开发者制定的希望HTML改变的元素规则,可以是一条或多条。

每条声明(declarations)由一个属性(property)和一个值(value)组成。

属性(property)是开发者希望设置的样式属性(style attribute)。

值(value)为属性的具体内容。

属性与值之间由冒号隔开,声明与声明直接由分号隔开。

CSS中的注释以 结束。

 h1 {color:red; font-size:14px;} 复制代码

上面这行代码的作用是将 h1 元素内的文字颜色定义为红色,同时将字体大小设置为 14 像素。



这是基本规则,具体规则请看CSS 基础语法。

2. 样式表书写规则

每个HTML元素都有初始的样式,但是也可以经过开发者书写而改变样式规则。

HTML的元素样式修改有以下的书写规则。

内部样式表(写在标签内部)
                  h1 {color:red; font-size:14px;}                复制代码
内联样式(写在HTML标签中)
                   复制代码
外部样式表(写在CSS文件中,引入到HTML里)
 h1 {color:red; font-size:14px;}                            复制代码
3. @规则(at-rule)

一个at-rule就是一个CSS语句,以@开头,后接标识符,最后以;结束。

@charset

@charset用于定义样式表中使用的字符编码。它必须写在样式表的最开头且前面不可有别的字符。

 @charset "UTF-8"; 复制代码
@import

@import用于导入外部CSS样式表文件。

  @import 'custom.css'; @import url("fineprint.css") print; 复制代码
@namespace

@namespace是用来定义使用在CSS样式表中的XML命名空间的@规则。

 @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

@page用于在打印文档时修改某些CSS属性。@page规则只能修改margin、orphans、widow 和 page breaks of the document,对其他属性的修改是无效的。

 @page {     size: 10in 20in;     margin: 10% 20%; } 复制代码
@keyframes

@keyframs通过定义动画序列中的关键帧来控制CSS动画不同步骤的状态。

 @keyframes slidein {     from {         margin-left: 100%;         width: 300%;     }     to {         margin-left: 0%;         width: 100%;     } } 复制代码
@supports

@supports用来检测规则组的规则是否生效。规则与@media类似

 @supports (display: flex) {     div {         display: flex;     } } 复制代码
@viewport

@viewport用于设置视口(viewport)的特性。

 @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-style用于自定义counter的样式

 @counter-style circled-alpha {     system: fixed;     symbols: Ⓐ Ⓑ Ⓒ Ⓓ Ⓔ Ⓕ Ⓖ Ⓗ Ⓘ Ⓙ Ⓚ Ⓛ Ⓜ Ⓝ Ⓞ Ⓟ Ⓠ Ⓡ Ⓢ Ⓣ Ⓤ Ⓥ Ⓦ Ⓧ Ⓨ Ⓩ;     suffix: " "; } .items {     list-style: circled-alpha; } 复制代码
@font-face

@font-face用于给网页指定文本字体。

 @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 } 复制代码
@doucment

@document如果满足条件组的条件,则规则生效(推延至 CSS Level 4 规范)

 @document url(http://www.w3.org/),                url-prefix(http://www.w3.org/Style/),                domain(mozilla.org),                regexp("https:.*") {       body {         color: purple;         background: yellow;     } } 复制代码

注:上面的@规则属性并非完整,还有少量相关的没有列出,需要详细列表的可以翻阅MDN

CSS是如何工作的?页面渲染机制

在讲CSS的工作流程之前,首先来简单看看页面的渲染机制。

页面渲染可分为下面5个步骤:

  1. 处理HTML来创建DOM tree;

  2. 处理CSS来创建CSSOM tree;

  3. 根据DOM跟CSSOM来合并render tree;

  4. 根据render tree来布局;

  5. 绘制render tree。

以上便是页面渲染的过程。

CSS的工作流程

从上面的页面渲染流程可以知道浏览器在解析了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)以及相关的性能问题与优化。

参考资料:

浏览器是如何工作的?

CSS是如何工作的?

CSS语法

CSS参考 MDN

层叠样式表

浏览器渲染页面的过程

【Hello CSS】系列

【Hello CSS】是以CSS基础概念为主题的系列文章,旨在帮助大家更深刻地了解并且提高CSS在各位开发者心目中的地位。由于鱼头我水平有限,文笔有限,如果各位在文章中发现有任何不合理,不正确的地方,还烦不吝指出,我会非常感谢的;如果通过文章有任何想法或疑问,也希望各位能积极留言,我们互相探讨;如果通过本系列文章有所收获,这就让鱼头我喜不自胜了!


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/242013.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号