rem 单位
rem是一个相对单位,它是根据html标签的font-size的字号来决定rem的值。
html {
font-size: 35px;
}
此时,1rem=35px。
媒体查询
媒体查询一个非常大的作用是:根据屏幕宽度修改html文字大小
。
媒体查询语法:
/*当设备宽度=375时,html字体大小=40px*/
@media (width:375px) {
html {
font-size: 40px;
}
}
@media (width:320px) {
html {
font-size: 30px;
}
}
怎么把我们测量的px 转换为适配的rem呢?
一般将设备宽度分成10等份,加入当前设备宽度是375px,那么html字体大小=37.5px(375 / 10 = 37.5)
rem值 = 某px值 / html字体大小(0.26666rem = 10 / 37.5)
flexible.js
通过媒体查询,检测不同的视口宽度,设定不同的html文字大小,元素设置rem单位后,可以达到元素适配效果。
体查询写起来超级麻烦,而且检测不够精确,因此我们使用 flexible.js 这个 js文件,通过js 实时检测屏幕窗口的变化实现检测视口宽度。
这个也是值得提倡使用的一种方式。
有了这个js文件,可以帮我们自动检测屏幕宽度,自动修改html文字大小,这样就可以让盒子配合rem完成适配。
<script src="./js/flexible.js"></script>
flexible 能够自动修改html文字大小。如果当前设备尺寸宽度为375px时,用375 / 10 =37.5px就是html的文字大小了。
LESS
Less是一个CSS预处理器, Less文件后缀是.less
扩充了 CSS 语言, 使 CSS 具备一定的逻辑性、计算能力。
.box {
width: 100px + 100;
// 注意:单位的转换 计算的时候以第一个单位为准
height: (100 / 37.5rem);
// height: (100rem / 37.5);
// height: 100px - 50;
margin: (20px * 5) auto;
padding: (10px / 5);
border: 1px + 2 * 3 solid red;
}
注意点:
-
计算以第一个单位为准, 尽量写到最后一个数字上。 比如
height: (100 / 37.5rem);
-
除法比较特殊,必须添加小括号。
-
计算别忘了先乘除后加减
less 嵌套
.father {
width: 500px;
height: 500px;
background-color: purple;
// 孩子
.son {
width: 200px;
height: 200px;
background-color: pink;
p {
color: red;
}
}
}
伪类和伪元素
我们在写伪类和伪元素的时候,经常使用 & 来代替父元素
.nav {
width: 100px;
height: 100px;
background-color: pink;
&::before {
content: '1';
}
&:hover::before {
color: red;
}
}
less 变量
变量最大的优点是: 方便使用和修改。
语法:
@自定义变量名: 值;
@fontSize: 16px;
@suibian: hotpink;
body {
background-color: @suibian;
}
less导入
less的导入实际 是 less 文件的导入。
使用less导入的好处是: 减少了html页面 的 link标签数量。
@import './变量.less';
@import url(./变量.less);
less 禁止导出
// out: false;