环境检测
检测node.js, node -v
检测 npm(node package manager) , npm -v
检测 Less, lessc -v
注释
/注释/ 在Less中,这种格式的注释能被编译, // 这种不能;
/*注释*/
编译结果:也是 /注释/
截图对比:左边是less环境,右边是编译后的css
变量
@变量名:值;
@baseColor:#e92322;
a{
color:@baseColor;
}
定义一个基本颜色变量,在 a
标签中引入;
看编译结果:
a {
color: #e92322;
}
截图对比:左边是less环境,右边是编译后的css
混入
可以将一个定好的样式,引入到另一个样式中,类似于函数的调用;
先定义一个基本样式,设置样式参数,并设置默认值
/* 定义一个类似函数的样式,@r 是圆角变量,:10px 是默认值*/
.addRadius(@r:10px){
border-radius:@r;
-webkit-border-radius:@r;
-moz-border-radius:@r;
}
.mydiv{
width: 100px;
height: 100px;
/*引入写好的样式,并传入参数*/
.addRadius();
}
编译结果:
.mydiv {
width: 100px;
height: 100px;
/*引入写好的样式,并传入参数,不使用参数的话,使用默认值 10px*/
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}
截图对比:
嵌套
实现选择器继承,可以减少代码量,同时使用代码结构更清晰
传统写法:
.my-header{}
.my-header > div{}
.my-header > div > h3{}
.my-header > div > h3::before{}
.my-header > div > h3 > a{}
.my-header > div > h3 > a:hover{}
Less 嵌套写法:
.my-header{
width: 200px;
height: 36px;
.addRadius();
> div{
width: 100%;
> h3 {
height: 20px;
&::before{
content: "";
display: table;
}
> a{
text-decoration: none;
&:hover{
text-decoration: underline;
}
}
}
}
}
编译结果:
.my-header {
width: 200px;
height: 36px;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}
.my-header > div {
width: 100%;
}
.my-header > div > h3 {
height: 20px;
}
.my-header > div > h3::before {
content: "";
display: table;
}
.my-header > div > h3 > a {
text-decoration: none;
}
.my-header > div > h3 > a:hover {
text-decoration: underline;
}
截图对比: