less使用ch1--认识语法

@charset "utf-8";

//注释------------------------------
/*我是可以被编译出来的*/
//不能被编译出来

//变量-------------------------------------
@test_width: 300px;

.div{
  width:@test_width;
}

//混合
.border{
  border:1px solid #666;
}
.div2{
  width:@test_width;
  .border;
}
//混合--带参数
.border2(@border_width){
  border:@border_width solid #222;
}
.test-mixin2{
  .border2(2px);
  color:red;
}
//混合--默认带值需要其他值可以传参
.border3(@border_width:2px){
  border:@border_width dotted #333;
  -webkit-border:@border_width dotted #333;
  -moz-border:@border_width dotted #333;
  -ms-border:@border_width dotted #333;
  -o-border:@border_width dotted #333;
}
.test-mixin3{
  .border3;
}
.test-mixin03{
  .border3(1px);
}

//匹配模式----------------------------------------
.sjborder{ //边框三角形:假如需要角朝下,(反方向)上边框设置颜色和solid,其他边框设为透明和dashed
  width:0px;
  height:0px;
  overflow: hidden;

  border-width:5px;
  border-color:red transparent transparent transparent;
  border-style:solid dashed dashed dashed; //兼容ie6黑边问题,没有的边设为dashed
}
//匹配模式--边框三角 上 右 下 左 相当于js的if
.triangle(bottom, @w:5px, @c:#ccc){ //角朝上
  border-width:@w;
  border-color:transparent transparent @c transparent;
  border-style:dashed dashed solid dashed;
}
.triangle(top, @w:5px, @c:#ccc){ //角朝下
  border-width:@w;
  border-color:@c transparent transparent  transparent;
  border-style:solid dashed dashed dashed;
}
.triangle(right, @w:5px, @c:#ccc){ //角朝左
  border-width:@w;
  border-color:transparent transparent transparent @c;
  border-style:dashed dashed dashed solid;
}
.triangle(left, @w:5px, @c:#ccc){ //角朝右
  border-width:@w;
  border-color:transparent @c transparent transparent;
  border-style:dashed solid dashed dashed;
}
.triangle(@_, @w:5px, @c:#ccc){ //@_ 始终都会匹配的,后面两个参数必须加上
  width:0px;
  height:0px;
  overflow: hidden;
}
//定位例子
.pos(r){
  position: relative;
}
.pos(a){
  position: absolute;
}
.pos(f){
  position: fixed;
}
.autosj1{
  .triangle(right);
  .pos(r);
}
.autosj2{
  .triangle(bottom);
}

//运算---------------------------------------------
@w:100px;
.w300{
  width:@w + 200; //运算没强制带单位,至少一个带就可以
  height:(@w+50)*2;
  background-color:#333 - 10;  //颜色很少运算
}

//嵌套--------------------------------------
ul{   //嵌套层数多的比层数少的加载慢
  li{
    a{
      span{
        color:red;
      }
      &:hover{ //& 代表上一层选择器
        color:yellow;
      }
    }
  }
}

//@arguments 变量-------------------------------
.border-arg(@w:5px, @type:solid, @c:red){
  border:@arguments;
}
.border-arg{
  .border-arg;
}

//避免编译:输出不正确的css语法或使用less不认识的语法(适用于滤镜等)-------
.prevent-compile{
  width: ~'calc(300px - 30px)'; //calc 让浏览器计算不是less计算
}

//!important关键字(所有都会加上important适用于调试)---------------------------------
.bor-im{
  .w300()!important;
}

 

posted @ 2017-04-04 23:14  Jesonhu  阅读(190)  评论(0编辑  收藏  举报
Top