赞
踩
cnpm install less -g
lessc -v 注意:要有“c”
lessc --version
在集成终端中打开目标文件输入命令
lessc main.less main.css
结果:
注意:在VScode中,可以通过下载一个插件:Easy LESS,这样在创建好一个.less文件后直接点击保存就可以生成一个同名的.css文件
在文档head标签内加入一下两行代码 ; link的 rel 的属性值一定要修改为 'stylesheet/less '
<
link
rel="stylesheet/less" href='css/demo.less'>
<
script
type="text/javascript" src='http://cdnjs.cloudflare.com/ajax/libs/less.js
/3.11.1/less.min.js'></
script
>
注意:link在前、script在后。 rel 属性 应该将 stylesheet 改为 stylesheet/less
以 @
开头 定义变量,并且使用时 直接 键入 @
名称。
@width: 10px;
@height: @width + 10px;#header {
width: @width;
height: @height;
}
#header {
width: 10px;
height: 20px;
}
混合(Mixin)是一种将一组属性从一个规则集包含(或混入)到另一个规则集的方法。假设我们定义了一个类(class)如下:
- .bordered {
-
- border-top: dotted 1px black;
-
- border-bottom: solid 2px black;
-
- }
- #menu a {
-
- color: #111;
-
- .bordered();
- }
-
- .post a {
-
- color: red;
-
- .bordered();
-
- }
& :代表的上一层选择器的名字,此例便是header
。
#header{ &:after{ content:"Less is more!"; } .title{ font-weight:bold; } &_content{//理解方式:直接把 & 替换成 #header margin:20px; } }
@ 规则(例如 @media 或 @supports)可以与选择器以相同的方式进行嵌套。@ 规则会被放在前面,同一规则集中的其它元素的相对顺序保持不变。这叫做冒泡(bubbling)。
.component {
width: 300px;
@media (min-width: 768px) {
width: 600px;
@media (min-resolution: 192dpi) {
background-image: url(/img/retina2x.png);
}
}
@media (min-width: 1280px) {
width: 800px;
}
}
编译为:
.component {
width: 300px;
}
@media (min-width: 768px) {
.component {
width: 600px;
}
}
@media (min-width: 768px) and (min-resolution: 192dpi) {
.component {
background-image: url(/img/retina2x.png);
}
}
@media (min-width: 1280px) {
.component {
width: 800px;
}
}
算术运算符 +、-、*、/ 可以对任何数字、颜色或变量进行运算。如果可能的话,算术运算符在加、减或比较之前会进行单位换算。计算的结果以最左侧操作数的单位类型为准。如果单位换算无效或失去意义,则忽略单位。无效的单位换算例如:px 到 cm 或 rad 到 % 的转换。
calc() 特例
为了与 CSS 保持兼容,calc() 并不对数学表达式进行计算,但是在嵌套函数中会计算变量和数学公式的值。
@var: 50vh/2;
width: calc(50% + (@var - 20px)); // 结果是 calc(50% + (25vh - 20px))
转义(Escaping)允许你使用任意字符串作为属性或变量值。
@min768: (min-width: 768px);
.element {
@media @min768 {
font-size: 1.2rem;
}
}
Less 内置了多种函数用于转换颜色、处理字符串、算术运算等
color("#aaa") 解析颜色,将代表颜色的字符串转换为颜色值
ceil(num) 向上取整
floor(num) 向下取整
percentage(num) 将浮点数转换为百分比字符串。
round(num) 四舍五入取整
pi() 返回圆周率 π (pi);
min(5, 10); 最小值
max(5, 10); 最大值
boolean(3<5) 返回boolean值
if((条件),true结果,false结果) 条件判断
例子
@some: foo;
div {
margin: if((2 > 1), 0, 3px);
color: if((iscolor(@some)), @some, black);
}
输出:
div {
margin: 0;
color: black;
}
each(列表/规则集,遍历规则)
例子:
@selectors: blue, green, red;
each(@selectors, {
.sel-@{value} {
a: b;
}
});
输出:
.sel-blue {
a: b;
}
.sel-green {
a: b;
}
.sel-red {
a: b;
}例子:
@set: {
one: blue;
two: green;
three: red;
}
.set {
each(@set, {
@{key}-@{index}: @value;
});
}
输出:
.set {
one-1: blue;
two-2: green;
three-3: red;
}
.....
@width: 0.5;
.class {
width: percentage(@width); // returns `50%`
}
有时,出于组织结构或仅仅是为了提供一些封装的目的,你希望对混合(mixins)进行分组。你可以用 Less 更直观地实现这一需求。
假设你希望将一些混合(mixins)和变量置于 #bundle 之下,为了以后方便重用或分发:
#bundle() {
.button {
display: block;
border: 1px solid black;
background-color: grey;
&:hover {
background-color: white;
}
}
.tab { ... }
.citation { ... }
}
现在,如果我们希望把 .button 类混合到 #header a 中,我们可以这样做:
#header a {
color: orange;
#bundle.button(); // 还可以书写为 #bundle > .button 形式
}
注意:如果不希望它们出现在输出的 CSS 中,例如 #bundle .tab,请将 () 附加到命名空间(例如 #bundle())后面。
#colors() {
primary: blue;
secondary: green;
}.button {
color: #colors[primary];
border: 1px solid #colors[secondary];
}
输出符合预期:
.button {
color: blue;
border: 1px solid green;
}
Less 中的作用域与 CSS 中的作用域非常类似。首先在本地查找变量和混合(mixins),如果找不到,则从“父”级作用域继承。
@var: red;
#page {
@var: white;
#header {
color: @var; // white
}
}
与 CSS 自定义属性一样,混合(mixin)和变量的定义不必在引用之前事先定义。因此,下面的 Less 代码示例和上面的代码示例是相同的:
@var: red;
#page {
#header {
color: @var; // white
}
@var: white;
}
块注释和行注释都可以使用:
/* 一个块注释
* style comment! */
@var: red;// 这一行被注释掉了!
@var: white;
“导入”的工作方式和你预期的一样。你可以导入一个 .less 文件,此文件中的所有变量就可以全部使用了。如果导入的文件是 .less 扩展名,则可以将扩展名省略掉:
@import "library"; // library.less
@import "typo.css";
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。