语义化更易读,seo;搜索引擎优化
块级元素:独占一行,不管内容长度
内联元素:紧跟着排列
盒模型:
标准盒模型,内容即为长宽,内外边距,框都不算。
怪异盒模型,内边距+内容+框=宽
标准盒模型写width:200px
得到的box-sizing大于200,
加上一句box-sizing:border-box。就缩到200了
不加的话就是默认content-box(内容占据全部的width)
data:image/s3,"s3://crabby-images/03445/0344523364a6dc02b4b7aaf5b32bf1bb799aeaee" alt=""
data:image/s3,"s3://crabby-images/db922/db922461d8933dbf83595cdcbf22743a1abe257f" alt=""
margin合并
当两个div有低外边距和顶外边距时,会造成盒子塌陷。
html
<body>
<div>第一个盒子</div>
<div>第二个盒子</div>
</body>
<style>
div {
font-size: 16px;
line-height: 1;
margin-top: 10px;
margin-bottom: 50px;
border: 1px solid #fcfcfc;
}
</style>
在两个div之间插入空div,也会合并。
margin负值
data:image/s3,"s3://crabby-images/a25ee/a25ee9f97770ae6df799b7b30f0821c3e89b8368" alt=""
BFC:Block formatting context(块级格式化上下文)
形成独立的渲染区域,内部原元素的渲染不会影响外界,用于清除浮动
data:image/s3,"s3://crabby-images/91f24/91f246bd46adae6f65ea7a87f125acce57716892" alt=""
正常div先写img,加上float:left,再写<p>,文字正常,但是整个div高度很小,造成图片浮动
data:image/s3,"s3://crabby-images/002a0/002a0b5ddc1d1072dcb0ce4dfce302c8e320f8ee" alt=""
加上
.bfc {
overflow: hidden;
}
data:image/s3,"s3://crabby-images/6f7ba/6f7baed56354176e1d21cf134ab2766333aa604c" alt=""
还是有问题:p占满了整个页面
data:image/s3,"s3://crabby-images/ad2aa/ad2aaa20fac81cd2050672c1237c69f108124f11" alt=""
解决方案:p也加上bfc
data:image/s3,"s3://crabby-images/db4fd/db4fdd0dfd74d1d2854a98827f745775dea47856" alt=""
圣杯布局
data:image/s3,"s3://crabby-images/eb189/eb1897a1110ca06f9b91f0eb900f7340baddab61" alt=""
data:image/s3,"s3://crabby-images/3db62/3db62007f231f3eadb5d14f3d14271d971a42052" alt=""
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div>
<div id="header">header</div>
<div id="content">
<div id="center" class="column">center</div>
<div id="left" class="column">left</div>
<div id="right" class="column">right</div>
</div>
<div id="footer">footer </div>
</div>
</body>
<style>
div {
text-align: center;
}
#header {
background-color: #f1f1f1;
}
#content {
padding-left: 300px;
padding-right: 200px;
}
#content #center {
background-color: #ddd;
width: 100%;
}
#content #left {
background-color: yellow;
width: 300px;
margin-left: -100%;
/* 拖到上面 */
position: relative;
right: 300px;
/* 继续左拖300px */
}
#content #right {
background-color: green;
width: 200px;
margin-right: -200px;
}
#content .column {
float: left;
}
#footer {
background-color: #f1f1f1;
clear: both;
/* 清除浮动 */
}
</style>
</html>
flex骰子布局
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div class="continer">
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
</div>
</body>
<style>
.continer {
background-color: #fff;
border: 1px solid #000;
display: flex;
flex-direction: row;
width: 100px;
height: 100px;
}
.point {
background-color: black;
border-radius: 50%;
width: 20px;
height: 20px;
margin: 7px;
}
.point:nth-child(2) {
align-self: center;
}
.point:nth-child(3) {
align-self: flex-end;
}
</style>
</html>
data:image/s3,"s3://crabby-images/6f796/6f7968e383750d5ae4d453fd46b7ffb432090f95" alt=""
row-reserve是从右往左排列
data:image/s3,"s3://crabby-images/56675/566750a96487a0fb38471ce37f5c20c2bd7ee24e" alt=""
space-between是左右靠边分布
space-around是等距离分布
data:image/s3,"s3://crabby-images/db0ab/db0ab2b4a39737c80c07558b495160decc0cdbcd" alt=""
baseline:不是靠近最底下。是靠近基线,而交叉轴和主轴的基线从左上角开始。
示例:
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div class="continer">
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
<div class="point"></div>
</div>
</body>
<style>
.continer {
background-color: #fff;
border: 1px solid #000;
display: flex;
flex-direction: row;
width: 100px;
height: 100px;
justify-content: flex-start;
align-items: flex-start;
flex-wrap: wrap;
}
.point {
background-color: black;
border-radius: 50%;
width: 20px;
height: 20px;
margin: 0;
}
/* .point:nth-child(2) {
align-self: center;
}
.point:nth-child(3) {
align-self: flex-end;
} */
</style>
</html>
data:image/s3,"s3://crabby-images/d9293/d92935405ba05f792995bfc4e9ce55e439415070" alt=""
relative和absolte定位
data:image/s3,"s3://crabby-images/1dec8/1dec8d20c40a9a70f90ce1dec6f5e585aa9277f8" alt=""
relative相对于自身,absolute相对于上一个父元素
在CSS中,relative和absolute是用于定位元素的两种方式
relative(相对定位)是相对于元素自身原来的位置进行定位。当你对一个元素使用position: relative后,可以通过top、bottom、left、right属性来移动这个元素。元素原来占据的空间仍然会保留,其他元素不会占据它原来的位置。例如,设置一个元素position: relative和top: 10px,这个元素会相对于它原来的位置向下移动10像素。
absolute(绝对定位)是相对于最近的已定位祖先元素(position属性值为relative、absolute或者fixed)来定位。如果没有已定位的祖先元素,那么它会相对于文档根元素(<html>)进行定位。当一个元素使用position: absolute时,它会脱离文档流,原来占据的空间不会被保留,其他元素会填补它原来的位置。比如,在一个相对定位的容器中有一个绝对定位的元素,这个绝对定位元素会以容器的左上角为参照点(如果没有其他偏移量设置)进行定位。
水平居中
data:image/s3,"s3://crabby-images/3dfe7/3dfe73de01022e64b42ea91bed7d8ed9dc4164f6" alt=""
html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div class="item1">hello world</div>
<div class="continer">
<div class="item2">hello world</div>
</div>
<div class="continer">
<div class="item3">hello world</div>
</div>
</body>
<style>
.continer {
width: 400px;
height: 200px;
background-color: gray;
border: 1px solid black;
}
.item1 {
text-align: center;
background-color: gray;
}
.continer .item2 {
margin: 0 auto;
background-color: pink;
width: 100px;
height: 100px;
}
.item3 {
position: absolute;
background-color: yellow;
top: 250px;
left: 50px;
left: 50%;
margin-left: -150px;
}
</style>
</html>
data:image/s3,"s3://crabby-images/8729a/8729ad5632131b54df1ef3b895d65bb72f2388e3" alt=""
垂直居中
data:image/s3,"s3://crabby-images/2bd4c/2bd4cf95a3d93855535119bd8091c53ec7665040" alt=""
data:image/s3,"s3://crabby-images/5dc49/5dc49b51a0e360fb5c188b0f07388111fb285ace" alt=""
line-heigh继承
data:image/s3,"s3://crabby-images/f8ee8/f8ee85cd6d2dd96334e9ab62d0fee3ed1758680e" alt=""
当1情况,直接继承50px,
当2情况,继承1.5*自身行高
当3情况,继承2*父元素行高。
rem?
data:image/s3,"s3://crabby-images/025a0/025a0126c3b054d8bf909d4e7935d56c9c8767bc" alt=""
data:image/s3,"s3://crabby-images/2ff41/2ff41eda4d6073ddb739da54bb6c95b96852bde8" alt=""