本仓库包含部分 HTML 知识及全面详实的 CSS 知识。便于开发中的快速查询。
前置知识:对 HTML5、CSS3 有一定了解。 说明:本仓库的名词并不专业严谨,只求便于理解。
在阅读以下内容之前可先阅读: HTML5&CSS3 basic (HTML5 和 CSS3 基础) | Github
head 元素 不会在页面上留下直接的内容,主要为页面相关资源及信息描述。
- 声明 - meta
<meta charset='utf-8'>
-charset
表示页面使用的字符集<mate name='viewport' content='width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no‘>
- 控制缩放(此属性对多端适配非常有用)name='viewport'
- 视口,表示页面显示的范围width=device-width
- 显示宽度,device-width
- 此处为设备宽度initial-scale=1.0
- 默认缩放,此处为1maximum-scale=1.0
- 最大缩放,此处为1user-scalable=no
- 用户缩放,此处为不允许用户缩放
- 标题 - title
- 样式 - style
- 链接 - link
- 脚本 - script
- 制定基础路径 - base
<base href="" />
(较少使用,设置此标签则表示本页面中所有链接都基于此路径)
body 元素 的内容会直接出现在页面上。
括号中的内容为对应标签在 HTML5 中的语义,更多内容可访问: https://developer.mozilla.org/zh-CN/docs/Glossary/语义#语义化元素
- 块级元素 - div / section(文章、文字) / article(文章) / aside(侧边栏、广告) / nav(菜单、导航) / header(头部) / footer(尾部) / i(icon 图标)
- 段落元素 - p
- 行内元素 - span / label / em(强调 - 斜体) / strong(强调 - 粗体)
- 表格元素 - table / thead / tbody / tr / td / th
- td
colspan
- 跨列rowspan
- 跨行
- td
- 列表元素 - ul / ol / li / dt / dd
- 表单元素 - form / input / select / textarea / button
- placeholder - 表单的默认显示(提示)内容
- form
target
- 表单提交的地址method
- 表单提交的方式(GET/POST)enctype
- (POST请求时)提交时使用的编码格式
- button
type
- 按钮类型button
普通按钮submit
提交按钮(form中生效),input
中type='submit'
与此作用相同reset
重置按钮(form中生效)
- 链接 - a / img
- a
a[href]
- 链接地址a[target]
- 指定在哪里打开链接,_self
(默认)在当前窗口打开;_blank
新窗口打开
- img
img[src]
- 图片地址img[alt]
- 替换资源,图片不可用时使用
- a
按默认样式分类: 块级 block、行内 inline、inline-block
按内容分类: https://www.w3.org/TR/html5/dom.html#kinds-of-content
- 块级元素可以包含行内元素
- 块级元素不一定能包含块级
- 行内元素一般不能包含块级元素
延伸:Text-level semantics | 22 Transitional Document Type Definition | Allowed nesting of elements in HTML 4 (and XHTML 1.0)
浏览器会自动为一些元素加默认样式。
CSS Reset CSS Tools: Reset CSS YUI CSS Reset
CSS Reset 重置默认样式 normalize.css | Github
2. CSS
CSS:层叠样式表(Cascading Style Sheet) CSS | CSS 参考 CSS 教程 | CSS 文档
选择器 {
属性(Property): 值(Value);
...
}
值后面的分号(
;
)可以不加,但建议为每一行加上分号
2.1.2 选择器
- 匹配 HTML 元素
- 有不同的匹配规则
- 多个选择器可叠加
2.1.2.1 选择器的分类
- 元素选择器 - a
- 伪元素选择器 - ::before
- 类选择器 - .class-name
- 属性选择器 - [Property-name=Property-value]
- 伪类选择器 - :hover
- ID 选择器 - #id-name
- 否定选择器 - :not(...)
- 通用选择器 - * (匹配所有元素)
- 组合选择器
2.1.2.2 选择器的权重
按先后顺序,同一级别下权重相同,不同级别下数值越小权重越高:
- ID 选择器
- 类 属性 伪类
- 元素 伪元素
- 其它
在同一元素被多个选择器选中时,浏览器会优先应用优先级较低的选择器的样式,再应用优先级高的选择器的样式,如果设定了重复的样式,则会使用优先级高的选择器的样式。
属性生效的其它规则:
- !important 优先级最高(除了另一个!important,谁不可覆盖)
- 内联样式 优先级高(高于 ID 选择器)
- 相同权重 后写的生效
2.2 CSS 布局
- 文字 - 字体、字重(font-weight)、颜色、大小、行高
- 盒子 - 背景、边框
- 页面 - 滚动、换行
- 装饰性样式 - 粗体(font-weight)、斜体(font-style:itatic)、下划线(text-decoration)
- 其它 - 指针(cursor:point)、CSS Hack (目前较少使用)
- 字体族(使用字体族时不要加引号) serif(衬线字体)、sans-serif(非衬线字体)、monospace(等宽字体)、cursive(手写体)、fantasy(花体)
- 多字体(fallback)
- 网络字体、自定义字体
- iconfont: https://www.iconfont.cn
在声明字体时先写平台独有的字体再加字体族是一个好的习惯
font-family: "PingFang SC", "Microsoft Yahei", monospace;由于苹果用户在安装Office后也会有
Microsoft Yahei
,但Microsoft Yahei
在Mac上的效果不如PingFang SC
因此将PingFang SC
在前面
/* 声明一个字体 */
@font-face {
font-family: "IF";
src: url("...")
}
font-family: "IF";
行高由 line box 的高度决定,line box 的高度由 inline box 的高度决定
2.3 CSS 布局
常用布局:
<table>
<thead>
<!-- <th></th>会将标题加粗显示,此处为示范,实际生产中不建议将<td>同<thead>混用 -->
<td>标题1</td><td>标题2</td><th>加粗标题</th>
</thead>
<tbody>
<tr>
<td>1-1</td><td>1-2</td><td>1-3</td>
</tr>
<tr>
<td colspan="2">2-1� (跨两列)</td><td rowspan=“2”>2-3 (跨两行)</td>
</tr>
<tr>
<td>3-1</td><td>3-2</td>
</tr>
</tbody>
</table>
<style>
.table {
display: table;
}
.table-row {
display: table-row;
}
.table-cell {
display: table-cell;
}
</style>
<div class="table">
<div class="table-row">
<div class="table-cell">1-1</div>
<div class="table-cell">1-2</div>
</div>
<div class="table-row">
<div class="table-cell">2-1</div>
<div class="table-cell">2-2</div>
</div>
</div>
盒子占用的空寂 = height/width(content) + padding + border
2.3.2.2 display - 元素的显示类型
常用属性:
- block(块级元素) - 有独立宽高,默认占据一行
- inline(内联元素/行内元素) - 没有独立宽高,默认不独立占据一行(类似于文本)
- inline-block(行内快极元素) - 对内相当于block有独立的宽高;对外相当于inline不会独立占据一行(类似于文本)
2.3.2.3 position - 元素的位置
常用属性:
- static(静态布局,默认) - 文档流。不可添加 z-index 样式。
- relative(相对定位) - 相对于元素本身,relative 的偏移(top/left/right),相对于元素本身,偏移后占用空间的计算仍按偏移之前的位置进行计算(偏移时不会改变它占据的空间)。可添加 z-index 样式定义层级。
- absolute(绝对定位) - 相对于最近的 relative 或 absolute(父元素) 定位,如果找不到则相对于 body 定位,脱离文档流,不会对其它元素的布局产生影响。可添加 z-index 样式定义层级。
- fixed(固定定位) - 相对于可视区域定位,脱离文档流,不会对其它元素的布局产生影响。可添加 z-index 样式定义层级。
2.3.3 flexbox 布局
- 弹性盒子
- 盒子不来就是并列的
兼容性 不好,慎用
<style>
.container{
width:800px;
height:200px;
display: flex;
}
.left{ /* 固定宽度 */
background: red;
display: flex;
width:200px;
}
.right{ /* 自适应宽度 */
background: blue;
display: flex;
flex:1;
}
</style>
<div class="container">
<div class="left">
左
</div>
<div class="right">
右
</div>
</div>
2.3.4 float 布局
- 元素“浮动”
- 脱离文档流 - 不影响其他元素的布局
- 不脱离文本流 - 影响文本的布局
对自身的影响:
- 形成快(BFC)- 自主控制宽高,无论是什么元素
- 位置尽量靠上
- 位置尽量靠左(float: left)/右(float: right)
对兄弟元素的影响:
- 上面一般贴非 float 元素
- 身边贴 float 元素
- 不影响其它元素的位置
- 影响其它快极元素的文本
对父级元素的影响:
- 从布局上”消失“
- 高度塌陷 - 可添加
overflow: auto
解决此问题
/* 解决 float 元素的父元素的影响 */
.container {
content: ' ';
clear: both; /* 清除浮动 */
display: block;
visibility: hidden;
height: 0;
}
<style>
.container{
width:800px;
height:200px;
}
.left{
background:red;
/* float:left; */
/* height:100%; */
width:200px;
position: absolute;
height:200px;
}
.right{
background:blue;
float:right;
width:200px;
height:100%;
}
.middle{
margin-left:200px;
margin-right:200px;
}
</style>
<div class="container">
<div class="left">
左
</div>
<div class="right">
右
</div>
<div class="middle">
中间
</div>
</div>
- 像文本一样排 block 元素
- 没有清除浮动的问题
- 需要处理间隙
<style>
.container{
width:800px;
height:200px;
font-size:0;
}
.left{
font-size:14px;
background:red;
display: inline-block;
width:200px;
height:200px;
}
.right{
font-size:14px;
background:blue;
display: inline-block;
width:600px;
height:200px;
}
</style>
<div class="container">
<div class="left">
左
</div>
<div class="right">
右
</div>
</div>
- 在不同设备上正常使用
- 一般主要处理屏幕大小
- 主要方法:
- 隐藏 + 折行 + 自适应空间
- rem(根据字体大小调整) / viewport / media query(媒体查询)
viewport - <mate name='viewport' content='width=device-wid th, initial-scale=1.0, maximum-scale=1.0, user-scalable=no‘>
效果属性:
- box-shadow - 投影(阴影)
- text-shadow - 文字投影(阴影)
- border-radius - 圆角
- background - 背景
- clip-path - 裁剪
2.4.1 box-shadow 阴影
- 营造立体感(层次感)
- 充当没有宽度的边框 -
box-shadow:0, 0, 0, 5px, #000;
就可以画出一个 5px 宽的黑色边框。 - 特殊效果
2.4.2 text-shadow 文字阴影
- 营造立体感(层次感)
- 品质感
2.4.3 border-radius 圆角
- 圆角矩形
border-radius: 10px;
- 圆形
border-radius: 50%;
- 半圆 / 扇形
border-top-left-radius: 100%;
- 奇怪的角
2.4.4 background 背景
- 纹理、图案
- 渐变
- 雪碧图动画
- 背景图尺寸适应
2.4.5 clip-path 裁剪
- 裁剪容器
- 按几何图形裁剪
- 自定义图形裁剪
CSS 中动画的类型:
- transition 补间动画
- keyframe 关键帧动画
- 逐帧动画
2.5.1 transition 补间动画
transition-timing-function(timing/easing)
2.5.2 animations(keyframe) 关键帧动画
- 基于 CSS 的另一种语言
- 通过工具编译成 CSS
- 添加了很多 CSS 不具备的特性
- 提升 CSS 文件的组织
常见的CSS 预处理器:
- less | 中文网 | Lee - Bootstarp | Github - 使用 js 编写,入门简单,复杂属性实现不友好
- scss(sass) | 中文网 | scss 在线转换 | Github - 使用 ruby 编写,需要编译,有基于 Node 的版本
CSS 预处理器 实现的功能:
- 嵌套 - 反应层级和约束
- 变量和计算 - 加少重复代码
- Extend 和 Mixin - 代码片段(类似于function)
- 循环 - 适用于复杂有规律的样式
- import - CSS 文件模块化
CSS 预处理器框架:
- SCSS
Compass - Page | Github 封装有兼容性问题的属性 - Less
Lesshat - Page | Github
EST - Page | Github - 提供现成的 mixin
- 类似js类库,封装常用功能
css 预处理器(less/scss)之间的语法对比
- less 和 scss 的嵌套语法完全相同。
&
表示与所在括号的选择器同级
- css(.css)
.wrapper { background: white; }
.wrapper a { font-size: 12px; }
.wrapper a:hover { background: red; }
- less(.less)
.wrapper {
background: white;
a { font-size: 12px;
&:hover { background: red; }
}
}
- scss/sass(.scss)
.wrapper {
background: white;
a { font-size: 12px;
&:hover { background: red; }
}
}
less 中使用 @
声明变量
scss 中使用 $
声明变量
作用 提高代码的可维护性,降低 css 样式的修改成本。
变量 包含单位,运算时也会带单位运算。
由于 css 中不存在变量,因此生成的 css 文件会将变量替换成计算后的结果,变量的声明会被丢弃。
- css(.css)
font-size: 12px;
background: #ffcccc;
border-color: red;
- less(.less)
@fontsice: 12px;
@bgcolor: red;
font-size: @fontsize;
background: lighten(@bgcolor, 40%);
border-color: @bgcolor;
- scss/sass(.scss)
$fontsice: 12px;
$bgcolor: red;
font-size: $fontsize;
background: lighten($bgcolor, 40%);
border-color: $bgcolor;
less 中的 mixin
声明 .mixin名称([参数(可选)]){ 样式 }
调用 .mixin名称([参数])
scss 中的 mixin
声明 @mixin mixin名称([参数(可选)]){ 样式 }
调用 @include mixin名称([参数])
作用 提高代码的可维护性,提取重复样式,在 css 中进行代码复用。
副作用:在过多使用后会导致生成的 css 样式文件的重复代码增多,可通过使用 extend(继承) 解决。
mixin(混入) 可认为是对重复样式的包装和复用,类似于面向对象语言中的方法,可带有参数。mixin 定义后可直接调用,mixin 中也可以调用 mixin。
由于 css 中不存在 mixin,因此生成的 css 文件会将 mixin 中的样式复制到调用的地方(变量会先进行计算),mixin 的声明会被丢弃。
注意 less 中不带参数的 mixin 与 css class 语法上只差一对小括号,css class 也可以作为 mixin 调用,且会保留在编译后的 css 文件中(mixin 会被丢弃),但个人不推荐将 css class 作为 mixin 调用,以免混淆。scss 中没有这个问题。
- css(.css)
.bg { background: green; font-size: 12px; border-color: red; }
- less(.less)
@bgcolor: green;
.mixin_bg(@bgcolor) {
background: @bgcolor;
font-size: 12px;
}
.bg {
.mixin_bg(@bgcolor)
border-color: red;
}
- scss/sass(.scss)
$bgcolor: green;
@mixin mixin_bg($bgcolor) {
background: $bgcolor;
font-size: 12px;
}
.bg {
@include mixin_bg($bgcolor)
border-color: red;
}
less 中使用 extend::extend(.类名)
scss 中使用 extend:@extend .类名
作用 提取选择器,将公共样式写在一起,在 css 中进行代码复用,解决 mixin 可能造成的生成 css 文件重复代码过多的问题。
extend(继承) 可认为是对 mixin 的升级,但二者在编译生成时有较大差异:extend 会将重复的样式提取出来放到单独的选择器中,可更好的完成代码的复用,并且不会造成过多的代码重复的问题。
- css(.css)
.bg .nav .banner { background: white; font-size: 12px; }
.nav { border: red; }
.banner { border: green; }
- less(.less)
.bg {
background: white;
font-size: 12px;
}
.nav:extend(.bg) {
border: red;
}
.banner {
&:extend(.bg)
border: green;
}
- scss/sass(.scss)
.bg {
background: white;
font-size: 12px;
}
.nav {
@extend .bg;
border: red;
}
.banner {
@extend .bg;
border: green;
}
less 中的循环
递归 .mixin名称(计数器) when (退出条件) { .mixin名称(计数器 - 1); 循环体; }
scss 中的循环
递归 @mixin mixin名称(计数器) { @if (退出条件) { @include mixin名称(计数器 - 1); 循环体; } }
循环 @for 计数器 from 起始点 through 结束点 { 循环体 }
作用 生成高度有规律的样式。
loop(循环) 循环生成样式。
less 中只能使用递归的方式实现循环;
sess 中可使用递归和 for 循环两种方式实现循环。
- css(.css)
.col-1 { width: 100ox; }
.col-2 { width: 200ox; }
.col-3 { width: 300ox; }
- less(.less)
递归:
.gen(@n) when (@n > 0) {
.gen(@n - 1);
.cot-@{n} {
width: 100px/3*@n;
}
}
gen(3);
- scss/sass(.scss)
递归
@mixin gen($n) {
@if ($n > 0) {
@include gen($n - 1);
.col-#{$n} {
width: 100px/3*$n;
}
}
}
gen(3);
循环
@for $i from 1 through 3 {
.col-#{$i} {
width: 100px/3*$i;
}
}
gen(3);
less 与 scss 中的 import 语法形式与 css 原生 @import
相同:@import "url"
作用 css 模块化,提高代码可维护性,解决 css 中默认 @import 不合并,不复用链接导致的 http 请求较多导致的性能问题。
import(模块化) 将引入的 css 模块合并为一个文件,在模块细分,文件细碎时能显著减少生成的 css 文件数量,有效减少 http 请求数量,提高性能。
- less(.less)
@import "url"
- scss/sass(.scss)
@import "url"
组织 优化 构建 维护
PostCSS | 中文网 Github | 插件 Gitter - 用 JavaScript 工具和插件转换 CSS 代码的工具
常用插件:
-
import - 模块合并
-
autoprefixer | config: browserslist - 自动加前缀(解决兼容性问题)
-
css-modules - 组件化
-
styled-components | Github - 组件化
browserslist - 浏览器列表(数据来自 can i use)