摘要:本篇则主要介绍的语法与是如何工作的。语法基本规则规则主要由两部分组成选择器与声明。属性与值之间由冒号隔开,声明与声明直接由分号隔开。是用来定义使用在样式表中的命名空间的规则。用来检测规则组的规则是否生效。
作者:陈大鱼头
github: KRISACHAN
在上一篇【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中的注释以 /* 开始并以 */ 结束。
/* selector {property: value} */
h1 {color:red; font-size:14px;}
上面这行代码的作用是将 h1 元素内的文字颜色定义为红色,同时将字体大小设置为 14 像素。
这是基本规则,具体规则请看CSS 基础语法。
2. 样式表书写规则每个HTML元素都有初始的样式,但是也可以经过开发者书写而改变样式规则。
HTML的元素样式修改有以下的书写规则。
<html>
<head>
<style>
h1 {color:red; font-size:14px;}
style>
head>
<body>
body>
html>
<html>
<head>
head>
<body>
<h1 style="color:red; font-size:14px;">h1>
body>
html>
h1 {color:red; font-size:14px;}
<html>
<head>
<link rel="stylesheet" href="style.css">
head>
<body>
<h1>h1>
body>
html>
3. @规则(at-rule)
一个at-rule就是一个CSS语句,以@开头,后接标识符,最后以;结束。
@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 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 {
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 (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的样式
/*
* @counter-style {
*
* }
*/
@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 }
@document如果满足条件组的条件,则规则生效(推延至 CSS Level 4 规范)
/*
* @document name(guide) {
*
* }
*/
@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是如何工作的?在讲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)以及相关的性能问题与优化。
参考资料:浏览器是如何工作的?
CSS是如何工作的?
CSS语法
CSS参考 MDN
层叠样式表
浏览器渲染页面的过程
【Hello CSS】系列【Hello CSS】是以CSS基础概念为主题的系列文章,旨在帮助大家更深刻地了解并且提高CSS在各位开发者心目中的地位。由于鱼头我水平有限,文笔有限,如果各位在文章中发现有任何不合理,不正确的地方,还烦不吝指出,我会非常感谢的;如果通过文章有任何想法或疑问,也希望各位能积极留言,我们互相探讨;如果通过本系列文章有所收获,这就让鱼头我喜不自胜了!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/7394.html
摘要:本篇则主要介绍的语法与是如何工作的。语法基本规则规则主要由两部分组成选择器与声明。用于自定义的样式用于给网页指定文本字体。 作者:陈大鱼头 github: KRISACHAN 在上一篇【Hello CSS】的序章CSS起源中介绍了CSS的诞生原因以及发展历史,了解了CSS的存在意义。从正篇篇开始将会正式开始介绍CSS这门语言的特点与功能。本篇则主要介绍CSS的语法与CSS是如何工...
摘要:对应多种语法规则可以为指定样式。渲染页面绘制到屏幕后,页面结构的改变也有可能导致渲染树重新计算,其中重排和重绘是最耗时的部分。 写了这么多class,color,background,display...; 也许有时候会疑惑,怎么就显示在页面上,改变元素的样式。 本文简明介绍整个解析,匹配,渲染过程 css 描述 css 是Cascading Style Sheets的简写,是一种样式...
摘要:分享嘉宾简介新时代布局的分享者是新加坡的国际知名专家陈慧晶。陈慧晶老师的分享主题介绍如下布局经常是令前端开发者头痛的一块工作。布局系统在这一小节中,慧晶老师主要分享了跟这新时代布局的三大栋梁。的首个公开工作草案是在发布的,而的则是发布。 作者:陈大鱼头 github: KRISACHAN 记录原因:2019年3月30日在深圳举行了第五届的CSS Conf,鱼头作为一枚CSS新手以及爱好者也...
摘要:分享嘉宾简介新时代布局的分享者是新加坡的国际知名专家陈慧晶。陈慧晶老师的分享主题介绍如下布局经常是令前端开发者头痛的一块工作。布局系统在这一小节中,慧晶老师主要分享了跟这新时代布局的三大栋梁。的首个公开工作草案是在发布的,而的则是发布。 作者:陈大鱼头 github: KRISACHAN 记录原因:2019年3月30日在深圳举行了第五届的CSS Conf,鱼头作为一枚CSS新手以及爱好者也...
摘要:通俗的说,预处理器用一种专门的编程语言,进行页面样式设计,然后再编译成正常的文件,以供项目使用。在开发过程中,使用扩展名为的文件来编写样式 webpack 前言 这篇文章是我在学习过程中对自己的一个记录和总结,也希望可以帮助到和我当初同样对webpack有困惑的小伙伴 我在自学webpack时也参考了很多大神的文章,参考的帖子太多就不一一谢过了,再次感谢各位大神的帮助 文章中的每个例...
阅读 2531·2021-09-24 10:29
阅读 3813·2021-09-22 15:46
阅读 2581·2021-09-04 16:41
阅读 2986·2019-08-30 15:53
阅读 1267·2019-08-30 14:24
阅读 3061·2019-08-30 13:19
阅读 2177·2019-08-29 14:17
阅读 3527·2019-08-29 12:55