盒子模型
盒子模型定义:
当对一个盒子模型进行文档布局的时候,浏览器的渲染引擎会根据标准之一的CSS盒子模型(CSS basic box model),将所有元素表示成一个个矩阵盒子。
一个盒子通常由四部分组成:border padding content margin
html
<style>
.box {
width: 200px;
height: 100px;
padding: 20px;
}
</style>
<div class="box">
盒子模型
</div>
标准盒子模型
IE 盒子模型:
Box-Sizing:
css
box-sizing: content-box|border-box|inherit:
css
<style>
.box {
width: 200px;
height: 100px;
padding: 20px;
box-sizing: border-box;
}
</style>
<div class="box">
盒子模型
</div>
如何理解BFC
data:image/s3,"s3://crabby-images/3675f/3675f622508dc1e55ba7e794acf2f998d3f4fa2d" alt=""
什么是BFC
BFC触发条件
data:image/s3,"s3://crabby-images/05b3d/05b3d771c6225c4c0af891709306d6519492fe34" alt=""
应用场景
1 防止margin重叠(塌陷)
html
<style>
p {
color: #f55;
background: #fcc;
width: 200px;
line-height: 100px;
text-align:center;
margin: 100px;
}
</style>
<body>
<p>Haha</p >
<p>Hehe</p >
</body>
html
<style>
.wrap {
overflow: hidden;// BFC
}
p {
color: #f55;
background: #fcc;
width: 200px;
line-height: 100px;
text-align:center;
margin: 100px;
}
</style>
<body>
<p>Haha</p >
<div class="wrap">
<p>Hehe</p >
</div>
</body>
data:image/s3,"s3://crabby-images/37dd6/37dd61053381697d787536270b74b2c0d58429b4" alt=""
清除内部浮动
html
<style>
.par {
border: 5px solid #fcc;
width: 300px;
}
.child {
border: 5px solid #f66;
width:100px;
height: 100px;
float: left;
}
</style>
<body>
<div class="par">
<div class="child"></div>
<div class="child"></div>
</div>
</body>
css
.par {
overflow: hidden;
}
data:image/s3,"s3://crabby-images/4ba95/4ba959781fd544ef36c963ba3ded69e6bab0fb84" alt=""
自适应多栏布局
html
<style>
body {
width: 300px;
position: relative;
}
.aside {
width: 100px;
height: 150px;
float: left;
background: #f66;
}
.main {
height: 200px;
background: #fcc;
}
</style>
<body>
<div class="aside"></div>
<div class="main"></div>
</body>
data:image/s3,"s3://crabby-images/7619e/7619e0d1748730d78041723d7b3c255715d258b7" alt=""
css
.main {
overflow: hidden;
}
响应式设计
data:image/s3,"s3://crabby-images/90398/9039819f025b721e8623f77fb030ae7cb09f55d9" alt=""
什么是响应式设计
实现方式
data:image/s3,"s3://crabby-images/75239/752390b4c0f2a4549bc5e0febd2d85168c93c4f4" alt=""
html
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
data:image/s3,"s3://crabby-images/cdff6/cdff6cc2a7f38b9db3c652f451dde4a37bf2f545" alt=""
媒体查询
data:image/s3,"s3://crabby-images/536aa/536aa0ee5223d3d5d002afff8c2142f551cce5a4" alt=""
css
@media screen and (max-width: 1920px) { ... }
data:image/s3,"s3://crabby-images/5403e/5403ed3d35bf1ec58abe042387c05fb43d1a915c" alt=""
css
@media screen (min-width: 375px) and (max-width: 600px) {
body {
font-size: 18px;
}
}
data:image/s3,"s3://crabby-images/3d773/3d77336c32f5ebf684b070f25b70a68096dd7fd6" alt=""
百分比
data:image/s3,"s3://crabby-images/efb1f/efb1f771539d194cbd0e667aacbe89105c0e81c0" alt=""
vm/vh
data:image/s3,"s3://crabby-images/2dd76/2dd76595fd9a78f051ea1028e96daf2c421c1fd1" alt=""
rem
data:image/s3,"s3://crabby-images/c4a41/c4a41d040cc2a5787cce074af3c9660fd088832c" alt=""
css
@media screen and (max-width: 414px) {
html {
font-size: 18px
}
}
@media screen and (max-width: 375px) {
html {
font-size: 16px
}
}
@media screen and (max-width: 320px) {
html {
font-size: 12px
}
}
为了更加准确的监听前端可视窗口的变化,可以在css之前插入javaScript标签。
javascript
//动态设置元素字体的大小
function init () {
var width = document.documentElement.clientWidth
document.documentElement.style.fontSize = width / 10 + 'px'
}
// 首次加载只加载 只加载一次
init()
window.addEventListener('orientationchange', init);
window.addEventListener('resize', init);
data:image/s3,"s3://crabby-images/07a8a/07a8aeb5748432ffef4bbc9a7cabb710f31d1af2" alt=""
小结