rem+less

一、rem基础

1.em和rem

我们前面的百分比布局和伸缩布局如果单独使用,页面发生变化的时候,我们的字体大小不会发生变化,而且元素的高度也不会随着屏幕的变化而变化。

(1)em

em也是一个相对单位,基准是参照父元素字体大小。

 <style>
      html {
        font-size: 12px;
      }
      #box {
        /* 相当于html的字体大小的2倍,也就是2*12=24em */
        font-size: 2em;
      }
      p {
        /* 相当于父元素#box的2倍,也就是24*2=48em */
        font-size: 2em;
      }
    </style>
  </head>
  <body>
    <div id="box">
      我是父元素
      <p>我是子元素</p>
    </div>

(2)rem 

rem (root em)是一个相对单位,基准是相对于html元素的字体大小。

 <style>
      html {
        font-size: 12px;
      }
      #box {
        /* 相当于html的字体大小的1倍,也就是1*14=24em */
        font-size: 1rem;
      }
      p {
        /* 相当于html字体大小的2倍,也就是12*2=24em */
        font-size: 2em;
      }
    </style>
  </head>
  <body>
    <div id="box">
      我是父元素
      <p>我是子元素</p>
    </div>

(3)总结 

由于px是固定单位,em的参照点又是变化的父元素,所以我们以后移动端开发的单位最好是选择rem.因为所有的元素的参照点都是html根元素的字体大小。如果我们再能设置在不同的移动设备终端,更改一下html的字体大小,那么对应的每个标签的字体大小也会跟着改变,也就是达到了不同终端的页面适配的目的。

二、媒体查询

1.什么是媒体查询

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

  • 使用 @media查询,可以针对不同的媒体类型定义不同的样式
  • @media 可以针对不同的屏幕尺寸设置不同的样式

2.媒体查询语法规范

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

(1)mediatype 查询类型 

   媒体类型主要有下面几种

   all:用于所有设备

   print:用于打印机和打印预览

   screen:用于电脑屏幕、平板和手机终端

(2)关键字

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

(3)媒体特性

每种媒体类型都具体各自不同的特性,根据不同媒体类型的媒体特性设置不同的展示风格。我们暂且了解三个。

(4) 媒体查询书写规则

三、less 基础

1.维护css弊端

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

2.Less 介绍 

Less(LeanerStyle Sheets 的缩写)是一门 CSS扩展语言,也成为CSS预处理器。

3.Less 使用

(1)变量

使用less以后,css中也可以定义变量了

@变量名:值;

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

比如新建01.less文件.里面代码如下

@color: #000;

div {
  background: @color;
}

 (2)vocode Less插件

Less嵌套

@color: #000;
@marginT: 10px;
div {
  background: @color;
  margin-top: @marginT;
  ul {
    list-style: none;
    li {
      width: 20%;
      float: left;
      background-color: @color;
    }
  }
}

生成的01.css代码如下:

div {
  background: #000;
  margin-top: 10px;
}
div ul {
  list-style: none;
}
div ul li {
  width: 20%;
  float: left;
  background-color: #000;
}

(4)&号拼接 

如果遇见 (交集|伪类|伪元素选择器),利用&进行连接

比如01.less代码如下:

a {
  &:hover {
    color: red;
  }
}

div&.box {
  color: yellow;
}

div {
  &::before {
    content: "";
    display: block;
  }
}

生成的01.css代码如下:

a:hover {
  color: red;
}
div.box {
  color: yellow;
}
div::before {
  content: "";
  display: block;
}

(5)less运算

less提供了加(+)、减(-)、乘(*)、除(/)算术运算。 

比如01.less代码如下:

@bd: 1px;
div {
  border: @bd+1 solid #000;
}

div {
  &.box {
    width: @bd*5+2;
  }
}

 生成的01.css代码如下:

div {
  border: 2px solid #000;
}
div.box {
  width: 7px;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值