
1.LESSCSS是一种动态样式语言,属于CSS预处理语言的一种,它使用类似CSS的语法,为CSS的赋予了动态语言的特性,如变量、继承、运算、函数等,更方便CSS的编写和维护。
LESSCSS可以在多种语言、环境中使用,包括浏览器端、桌面客户端、服务端。
Koala 考拉 --编译的时候如果没有建CSS文件夹 Koala会自动给你生成一个
如何设置语言
如何编译
- 
让webstorm支持less编译:
安装node.js --- 这是一个包管理工具 以后还会用到
WIN+R
输入 npm install less
.....
注释
// 只在less中显示
/**/ 会在编译好的css文件中显示
变量
less中的写法
@ly_width:100px;
.box {
width:@ly_width;
}编译后在css中显示的是
.box {
width:100px;
}定义变量用@
混合
解决border-radius兼容
.border_radius (@radius: 5px) {
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
-ms-border-radius: @radius;
-o-border-radius: @radius;
border-radius: @radius;
}less中的写法
@ly_width:100px;
@ly_height:200px;
@ly_color:green;
.border(@border_width:3px;) {
border:@border_width solid red;
}
.one {
width:@ly_width;
height:@ly_height;
background-color:@ly_color;
.border();
}编译后在css中显示的是
.one {
width: 100px;
height: 200px;
background-color: #008000;
border: 3px solid #ff0000;
}less中的写法
@ly_width:100px;
@ly_height:200px;
@ly_color:green;
.border(@border_width) {
border:@border_width solid red;
}
.one {
width:@ly_width;
height:@ly_height;
background-color:@ly_color;
.border(1px);
}编译后在css中显示的是
.one {
width: 100px;
height: 200px;
background-color: #008000;
border: 1px solid #ff0000;
}先上less中的代码 如果想在.one中应用.border的样式怎么办?
@ly_width:100px;
@ly_height:200px;
@ly_color:green;
.border {
border:1px solid red;
}
.one {
width:@ly_width;
height:@ly_height;
background-color:@ly_color;
}写成下面的样子
@ly_width:100px;
@ly_height:200px;
@ly_color:green;
.border {
border:1px solid red;
}
.one {
width:@ly_width;
height:@ly_height;
background-color:@ly_color;
.border;
}编译后在css中显示的是.border { border:1px solid red; } .one { width: 100px; height: 200px; background-color: #008000; border: 1px solid red; }
不带参数的混合
带参数的混合---不带默认值 (可以传多个参数,以逗号或者分号隔开,推荐用分号 下面以一个参数为例)
带参数的混合---带默认值 (可以传多个参数 下面以一个参数为例)
在解决css3兼容性时候经常用到
匹配模式
less中的写法
//定义上,下,左,右边框的样式
.border(top;@border_width:5px;@border_color:red){
border-top:@border_width solid @border_color;
}
.border(bottom;@border_width:5px;@border_color:red){
border-bottom:@border_width solid @border_color;
}
.border(left;@border_width:5px;@border_color:red){
border-left:@border_width solid @border_color;
}
.border(right;@border_width:5px;@border_color:red){
border-right:@border_width solid @border_color;
}
//如果想写通用的样式 可以在下面的代码中写 格式是固定的
.border(@_,@border_width:5px;@border_color:red){
border-color:yellow;
}
.border_use1 {
//选择和if差不多 如果是left就调用上面对应的
.border(left);
}
.border_use2 {
//选择和if差不多 如果是right就调用上面对应的
.border(right);
}编译后在css中显示的是
.border_use1 {
border-left:5px solid #ff0000;
border-color:yellow;
}
.border_use2 {
border-right:5px solid #ff0000;
border-color:yellow;
}可以理解成if 和上面的混合有些相似
运算
less中的写法
@ly_width:100px;
.one {
width:@ly_widht + 100;
}编译后在css中显示的是
.one {
width:200px;
}运算提供了加,减,乘,除操作,还可以做属性值和颜色的运算...
嵌套
html结构
<p class="one"> <p class="two"></p> </p>
less中的写法
@ly_width:100px;
@ly_height:200px;
@ly_color:red;
.one {
width:@ly_width;
height:@ly_height;
background-color:@ly_color;
.two {
background-color: green;
}
}编译后在css中显示的是
.one {
width: 100px;
height: 200px;
background-color: #ff0000;
}
.one .two {
background-color: green;
}可以在一个选择器中嵌套另一个选择器,代码看起来层次分明,提高代码可维护性
@arguments变量
less中的写法
//和前面提到的混合一起举个栗子
.border(@border_width;@border_style;@border_color){
border:@arguments;
}
.one {
.border(1px;solid;red);
}编译后在css中显示的是
.one {
border:1px solid #ff0000;
}可以包含所有的变量,将变量一起处理
