less

lishihuan大约 3 分钟

less

1. less 基础

1.1 维护css弊端

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

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

1.不支持变量,不利于复用

2.不支持运算

变量、函数、运算

1.2 Less 介绍

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

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

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

Less中文网址:http://open in new windowlessopen in new windowcss.cn/open in new window

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

一句话:Less是一门 CSS 预处理语言,它扩展了CSS的动态特性。

1.3 Less安装

1.安装nodejs,可选择版本(8.0),网址:http://nodejs.cn/download/open in new window

2.检查是否安装成功,使用cmd命令(win10是window+r 打开运行输入cmd) ---输入node –v查看版本即可

3.基于nodejs在线安装Less,使用cmd命令npm install -g less即可

4.检查是否安装成功,使用cmd命令 lessc -v查看版本即可

2.Less 使用

文件以less 为后缀,例如:style.less

2.1. Less 使用之变量

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

@变量名:值;
  • 必须有@为前缀
  • 不能包含特殊字符
  • 不能以数字开头
  • 大小写敏感
@color: pink;

2.2 Less 嵌套

/*css 写法*/
#header .logo {
	width: 300px;
}

/* Less 嵌套 写法*/
#header {
    .logo {
    	width: 300px;
	} 
}

交集|伪类|伪元素选择器 使用&

  • 内层选择器的前面没有 & 符号,则它被解析为父选择器的后代;

  • 如果有 & 符号,它就被解析为父元素自身或父元素的伪类。

/*css 写法*/
a:hover{
	color:red;
}
/* Less 嵌套 写法*/

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

2.3 Less 运算

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

/*Less 里面写*/
@witdh: 10px + 5;
div {
    border: @witdh solid red;
}
/*生成的css*/
div {
  border: 15px solid red;
}
/*Less 甚至还可以这样 */
width: (@width + 5) * 2;

width:10px + 4;

width:10px * 4;

width:10 / 5px;===> 2px(只有一个值有单位,则运算结果就取该单位)

width:82rem / 50px; ===> 1.64rem(2个不同的单位,取第一个值的单位)
  • 运算符中间左右有个空格隔开 1px + 5
  • 对于两个不同的单位的值之间的运算,运算结果的值取第一个值的单位
  • 如果两个值之间只有一个值有单位,则运算结果就取该单位
  • 颜色也可以进行计算

2.4 导入

// 导入common.css文件
@import "common";
// @import 导入的意思 可以把一个样式文件导入到另外一个样式文件里面
// link 是把一个 样式文件引入到 html页面里面

3.Less 编译

html 不能直接使用less,所以需要编译,将其转为 css文件再通过 link 引入到HTML页面中

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