3.变量、使用方面的区别
less:
1.变量: 使用@变量名:变量值
2.混合:无参混合,代参混合
3.less的匹配模式,会根据调用时提供的条件只寻找与之匹配的mixins执行,其中@_表示永远须要执行的部分
4.less中的运算,加减乘除可带、可不带单位;颜色运算时,分成绿蓝三组进行运算,组内可进位,组间互不干涉
5.包含了传进来的全部参数:border:@arguments;
6.less中的嵌套保留了html的代码结构 1)嵌套默认是后代选择器,若是须要子代选择器,则在子代前加>2).&表示上一层 &:表示上一层的hover事件
sass:
1.使用$变量名:变量值,若是变量须要须要在字符中嵌套,则需使用#加大括号包裹 :border-#{$left}:10px solid #ccc;
2.会使用单位
3.嵌套:选择器嵌套 伪类嵌套 属性嵌套
选择器嵌套 ul{li{}} 后代 ul{>li{}}子代 &表示上一级 属性嵌套:属性名与大括号之间必须有: border:{color:red}
四、混合宏、继承、占位符
①混合宏:声明:@mixin name($param:value){}
调用:@include name(value);
>>>声明时,能够有参,能够无参;可带默认值,也可不带;可是,调用时,必须符合声明规范。同less
>>>优势;能够传参,不会生成同名class;
>>>缺点:会将混合宏中的代码,copy到对应的选择器中,产生冗余代码!
②继承:声明:.class{} 调用:@extend .class;
>>>优势:继承的相同代码,会提取到并集选择器中,减小冗余代码
>>>缺点:没法进行传参,会在css中,生成一个同名class
③占位符:声明:&class{} 调用:@extend %class;
>>>优势:继承相同代码,会提早到并集选择器;不会生成同名的class选择器
>>>缺点:没法进行传参
综上所述:当须要传递参数时,用混合宏;当有现成的class时用继承;当不须要参数,也不须要class时,用占位符
五、if条件结构:
@if 条件{}
@else{}
六、for循环结构:
@for $i from 1 to 10{} 不包含10;
@for $i from 1 through 10{} 包含10;
七、while循环结构:
$j:1;
@while $j<10{
.while#{$j}{
border:#{$j}px solid red;
}
$j:$j+1;
}
八、each循环遍历
@each item in a,b,c,d{
//item表示每一项
}
九、函数:
@function func($length){
$length1:$length*5;
@return $length1;
}
调用:func(10px);
十、使用...将传进来的全部参数,接收到一个变量中
@mixin bordeRadius($param1...){
//使用...将传进来的全部参数,接收到一个变量中
border-radius:$param1;
-webkit-border-radius:$param1;
}