网络布局的媒体查询
@media
JS驱动rem(实时变化)
主要代码
// 实现一个事儿:让html标签的字号,是屏幕此时宽度的1/10。
// 想清楚:屏幕的总宽度是10rem。除几,屏幕总宽度就是几rem。
// 当屏幕尺寸改变的时候
window.onresize = function() {
document.documentElement.style.fontSize = document.documentElement.clientWidth / 10 + 'px';
};
// 页面打开那一瞬间,也设一下
document.documentElement.style.fontSize = document.documentElement.clientWidth / 10 + 'px';
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
* {
margin: 0;
padding: 0;
}
.box1 {
width: 2.5rem;
height: 1rem;
background-color: orange;
float: left;
}
.box2 {
width: 2.5rem;
height: 1rem;
background-color: rgb(190, 10, 160);
float: left;
}
.box3 {
width: 2.5rem;
height: 1rem;
background-color: rgb(35, 150, 7);
float: left;
}
.box4 {
width: 2.5rem;
height: 1rem;
background-color: rgb(233, 77, 5);
float: left;
}
</style>
</head>
<body>
<div class="box1"></div>
<div class="box2"></div>
<div class="box3"></div>
<div class="box4"></div>
<script>
// 实现一个事儿:让html标签的字号,是屏幕此时宽度的1/10。
// 想清楚:屏幕的总宽度是10rem。除几,屏幕总宽度就是几rem。
// 当屏幕尺寸改变的时候
window.onresize = function() {
document.documentElement.style.fontSize = document.documentElement.clientWidth / 10 + 'px';
};
// 页面打开那一瞬间,也设一下
document.documentElement.style.fontSize = document.documentElement.clientWidth / 10 + 'px';
</script>
</body>
</html>
媒体查询驱动rem(边界会有咯噔感)
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
@media screen and (min-width:320px) {
html {
font-size: 21.33px
}
}
@media screen and (min-width:360px) {
html {
font-size: 24px
}
}
@media screen and (min-width:375px) {
html {
font-size: 25px
}
}
@media screen and (min-width:384px) {
html {
font-size: 25.6px
}
}
@media screen and (min-width:400px) {
html {
font-size: 26.67px
}
}
@media screen and (min-width:414px) {
html {
font-size: 27.6px
}
}
@media screen and (min-width:424px) {
html {
font-size: 28.27px
}
}
@media screen and (min-width:480px) {
html {
font-size: 32px
}
}
@media screen and (min-width:540px) {
html {
font-size: 36px
}
}
@media screen and (min-width:720px) {
html {
font-size: 48px
}
}
@media screen and (min-width:750px) {
html {
font-size: 50px
}
}
* {
margin: 0;
padding: 0;
}
.c1 {
float: left;
width: 3rem;
height: 3rem;
background-color: orange;
}
.c2 {
float: left;
width: 3rem;
height: 3rem;
background-color: red;
}
.c3 {
float: left;
width: 3rem;
height: 3rem;
background-color: blue;
}
.c4 {
float: left;
width: 3rem;
height: 3rem;
background-color: green;
}
.c5 {
float: left;
width: 3rem;
height: 3rem;
background-color: skyblue;
}
</style>
</head>
<body>
<div class="c1"></div>
<div class="c2"></div>
<div class="c3"></div>
<div class="c4"></div>
<div class="c5"></div>
</body>
</html>
网格布局
- display:grid 网格容器
- grid-template-columns 列宽
- grid-template-rows 行高
- grid-gap 间距
跨行 跨列
- grid-column-start:1 列从哪个开始
- grid-column-end:3 列到那个结束(不包含)
- grid-column:1 / span 从第一根线开始,合并3个单元格
- grid-row-start:1 行从哪个开始
- grid-row-end:3 行到哪个结束(不包含)
- grid-row:1/span 3 同上
minmax函数
minmax(300px,600px)
自定义网络模板
grid-template-area:模板样式
grid-area: 选择模板