# Less

# 维护 css 的弊端

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

  • CSS 需要书写大量看似没有逻辑的代码,冗余度比较高
  • 不方便维护及扩展,不利于复用
  • CSS 没有很好的计算能力
  • 非前端开发工程师来讲,往往会因为缺少 CSS 编写经验而很难编写出组织良好且易于维护的 CSS 代码项目

# Less 介绍

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

作为 CSS 的一种形式的扩展,它并没有减少 CSS 的功能,而是在现有的 CSS 语法上,为 CSS 加入程序式语言的特性

它在 CSS 的语法基础上,引入了变量,Mixin (混入), 运算以及函数等功能,大大简化了 CSS 的编写,并且降低了 CSS 的维护成本,就像它的名字一样,Less 可以让我们用更少的代码做更多的事情

常见 CSS 预处理器 : Sass, Less, Stylus

# Less 使用

首先新建一个后缀名为 less 的文件,在这个 less 文件中书写 less 语句

  • Less 变量
  • Less 编译
  • Less 嵌套
  • Less 运算

# 变量命名规范

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

# Less 嵌套

如果遇见 (交集 | 伪类 | 伪元素选择器)

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

# Less 运算

任何数字,颜色或者变量都可以参与运算. Less 提供了加减乘除算数运算

** 注意 : **

  • 运算符中间左右有个空格隔开
  • 对于两个不同单位的值之间的运算,运算结果的值取第一个值的单位
  • 如果两个值只有一个值有单位,则运算结果就取该单位