rem适配布局

 流式布局和flex布局主要针对宽度布局,高度是写死的。那么怎么样能让屏幕发生变化的时候元素高度和宽度等比例缩放,以及页面布局文字也随着屏幕大小变化而变化?

使用rem适配布局就可以实现以上需求。

rem基础

rem (root em)是一个相对单位,类似于em , em是父元素字体大小。

不同的是rem的基准是相对于html元素的字体大小
比如,根元素( html )设置font-size=12px;,非根元素设置width:2rem;则换成px表示就是24px.

那么怎么根据不同的屏幕大小设置html元素的字体大小?

媒体查询

媒体查询(Media Query )是CSS3新语法。

  • 使用@media查询,可以针对不同的媒体类型定义不同的样式
  • @media可以针对不同的屏幕尺寸设置不同的样式
  • 当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面
  • 目前针对很多苹果手机、Android手机,平板等设备都用得到多媒体查询

语法规范

@media mediatype and|not|only (media feature){
    CSS-Code;
}
  • 用@media开头  注意@符号
  • mediatype : 媒体类型
  • 关键字 : and not only
  • media feature  :媒体特性   必须有小括号包含

媒体类型

关键字

将媒体类型或多个媒体特性连接到起做为媒体查询的条件。

  • and :可以将多个媒体特性连接到一起,相当于“且”的意思。
  • not:排除某个媒体类型,相当于“非”的意思,可以省略。
  • only:指定某个特定的媒体类型,可以省略。

媒体特性

        每种媒体类型都具体各自不同的特性,根据不同媒体类型的媒体特性设置不同的展示风格。我们暂且了解三个。注意要加小括号包含他们。

案例:根据页面宽度改变背景颜色

按照从大到小的或者从小到大的思路:
        注意我们有最大值max-width和最小值min-width都是包含等于的

        1、当屏幕小于540像素,背景颜色变为粉色(x<=539 )
        2、当屏幕大于等于540像素并且小于等于969像素的时候背景颜色为蓝色(540=<x<= 969 )

        3、当屏幕大于等于970像素的时候,背景颜色为绿色(( x >= 970 )

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      /* 小于等于539,背景色为粉色 */
      @media screen and (max-width: 539px) {
        body {
          background-color: pink;
        }
      }
      /* 540~969,背景色为蓝色 */
      @media screen and (min-width: 540px) and (max-width: 969px) {
        body {
          background-color: blue;
        }
      }
      /* 大于等于970 ,背景颜色为绿色 */
      @media screen and (min-width: 970px) {
        body {
          background-color: green;
        }
      }
    </style>
  </head>
  <body></body>
</html>

媒体元素+rem实现元素动态大小变化

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      .top {
        height: 1rem;
        line-height: 1rem;
        font-size: 0.5rem;
        background-color: goldenrod;
        color: #fff;
        text-align: center;
      }
      @media screen and (min-width: 320px) {
        html {
          font-size: 50px;
        }
      }
      @media screen and (min-width: 640px) {
        html {
          font-size: 100px;
        }
      }
    </style>
  </head>
  <body>
    <div class="top">购物车</div>
  </body>
</html>

引入资源

引入资源就是针对于不同的屏幕尺寸调用不同的css文件

Less基础

css弊端

CSS是一门非程序式语言,没有变量、函数、SCOPE(作用域)等概念。

  • CSS需要书写大量看似没有逻辑的代码,CSS冗余度是比较高的。
  • 不方便维护及扩展,不利于复用。
  • CSS没有良好的计算能力。

Less介绍

        Less ( Leaner Style Sheets 的缩写)是一门CSS扩展语言,也成为CSS预处理器。
        作为CSS的一种形式的扩展,它并没有减少CSS的功能,而是在现有的CSS语法上,为CSS加入程序式语言的特性。
        它在CSS的语法基础之上,引入了变量,Mixin(混入),运算以及函数等功能,大大简化了CSS的编写,并且降低了CSS的维护成本,就像它的名称所说的那样,Less可以让我们用更少的代码做更多的事情。

        Less中文网址:less网址

        常见的CSS预处理器: Sass、Less、Stylus

Less使用

我们首先新建一个后缀名为less的文件,在这个less文件里面书写less语句。

Less变量

变量是指没有固定的值,可以改变的。因为我们CSS中的一些颜色和数值等经常使用。

变量名必须有@为前缀,不能包含特殊字符,不能以数字开头,大小写敏感。

Less编译

        本质上,Less包含一套自定义的语法及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器,编译生成对应的CSS文件。
        所以,我们需要把我们的less文件,编译生成为css文件,这样我们的html页面才能使用。

Easy LESS插件用来把less文件编译为css文件
安装完毕插件,重新加载下vscode。只要保存一下Less文件,会自动生成cSS文件。

Less嵌套

  • 内层选择器的前面没有&符号,则它被解析为父选择器的后代;
  • 如果有&符号,它就被解析为父元素自身或父元素的伪类。

 
Less运算

任何数字、颜色或者变量都可以参与运算。就是Less提供了加(+)、减(-)、乘(*)、除(/)算术运算。


        


 

  • 72
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值