流式布局和flex布局主要针对宽度布局,高度是写死的。那么怎么样能让屏幕发生变化的时候元素高度和宽度等比例缩放,以及页面布局文字也随着屏幕大小变化而变化?
使用rem适配布局就可以实现以上需求。
rem (root em)是一个相对单位,类似于em , em是父元素字体大小。
不同的是rem的基准是相对于html元素的字体大小。
比如,根元素( html )设置font-size=12px;,非根元素设置width:2rem;则换成px表示就是24px.
那么怎么根据不同的屏幕大小设置html元素的字体大小?
媒体查询(Media Query )是CSS3新语法。
@media mediatype and|not|only (media feature){
CSS-Code;
}
将媒体类型或多个媒体特性连接到起做为媒体查询的条件。
每种媒体类型都具体各自不同的特性,根据不同媒体类型的媒体特性设置不同的展示风格。我们暂且了解三个。注意要加小括号包含他们。
按照从大到小的或者从小到大的思路:
注意我们有最大值max-width和最小值min-width都是包含等于的1、当屏幕小于540像素,背景颜色变为粉色(x<=539 )
2、当屏幕大于等于540像素并且小于等于969像素的时候背景颜色为蓝色(540=3、当屏幕大于等于970像素的时候,背景颜色为绿色(( x >= 970 )
Document
Document
购物车
引入资源就是针对于不同的屏幕尺寸调用不同的css文件
CSS是一门非程序式语言,没有变量、函数、SCOPE(作用域)等概念。
Less ( Leaner Style Sheets 的缩写)是一门CSS扩展语言,也成为CSS预处理器。
作为CSS的一种形式的扩展,它并没有减少CSS的功能,而是在现有的CSS语法上,为CSS加入程序式语言的特性。
它在CSS的语法基础之上,引入了变量,Mixin(混入),运算以及函数等功能,大大简化了CSS的编写,并且降低了CSS的维护成本,就像它的名称所说的那样,Less可以让我们用更少的代码做更多的事情。
Less中文网址:less网址
常见的CSS预处理器: Sass、Less、Stylus
我们首先新建一个后缀名为less的文件,在这个less文件里面书写less语句。
变量是指没有固定的值,可以改变的。因为我们CSS中的一些颜色和数值等经常使用。
变量名必须有@为前缀,不能包含特殊字符,不能以数字开头,大小写敏感。
本质上,Less包含一套自定义的语法及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器,编译生成对应的CSS文件。
所以,我们需要把我们的less文件,编译生成为css文件,这样我们的html页面才能使用。
Easy LESS插件用来把less文件编译为css文件
安装完毕插件,重新加载下vscode。只要保存一下Less文件,会自动生成cSS文件。
任何数字、颜色或者变量都可以参与运算。就是Less提供了加(+)、减(-)、乘(*)、除(/)算术运算。