less的用法

less是一门css预处理语言,它扩充了 CSS 语言,增加了诸如变量、混合(mixin)、函数等功能,让 CSS 更易维护、方便制作主题、扩充。良好的使用可以让代码输入节省很多时间

一般less的使用,可以下载一个叫koala的软件 百度即可,安装时最好不要有中文路径,然后在文件下创建一个Less格式(文件后缀.less)的文件 在koala中添加文件夹后右键编译文件,就会生成一个css文件,这样就可以在less文件中书写时,就会把编译后的css样式自动写在css文件里,使用的时候引用css文件 就可以了。

下面是less一些常见的用法:
首先了解什么是变量,变量就是没有固定的值是可以改变的,在使用时我们需要给变量取个名字叫变量名,然后在进行声明

  1. 变量: 存储数据的容器,数据本身可以修改
  2. 声明:@变量名称:变量的值;
    less的使用可以有几种用法

使用

属性值中:@变量名称

选择器名中:@{变量名称}

属性名中:@{变量名称}

在路径中使用:@{变量名称} **注意加引号

在变量值中使用:@变量名称

在变量名中使用:@变量名称

@w: 100px;
@b: box;
@bg: background;

#{@b} {
    width: @w;
    height: @w;
    @{bj}: red
}

显示为

#box {
    width: 100px;
    height: 100px;
    background: red;
}

可以给变量增添运算

#{@b}1 {
  width: @w*2;
  height: @w*3;
  background: red;
}  

显示为

#box1 {
    width: 200px;
    height: 300px;
    background: red;
}

运算的使用

运算时的单位识别
如果运算符的左右两侧都有单位,
加减乘除识别的是运算符左侧的单位
乘法识别的是运算符右侧的单位

@w: 100rem;
@rem: 64px;
#box {
    width: @w/@rem;
    width: @w*@rem;
    width: @w+@rem;
    width: @w-@rem;
}

显示为

#box {
    width: 1.5625rem;
    width: 6400px;
    width: 164rem;
    width: 36rem;
}

*变量名重名之后,后边会覆盖前边的


@w2: 100;

@rem2: 64;

#box {
    width: @w2+@rem2+px;
}

显示

#box {
    width:164 px; 
}

这样写在单位和值之间用空格,尽量在变量中添加单位


作用域

写在{}之间 叫做局部变量,只可以在{}之间起作用

@w: 100px;
.box {
    @w: 200px; 
    width: @w;
}
#box {
    width: @w;
}

显示

.box {
    width: 200px;
}
#box {
    width: 100px;
}


less中的嵌套

优先识别自己样式

#box {
    @w: 100px;
    width: @w*3;
    height: 200px;
}
li {
    @w: 200px;
    width: @w;
}
div {
    width:@w;
}
a {
  color: red;
  &:hover { // &上一级
    color: blue;
  }
}

显示

#box {
    width: 300px;
    height: 200px;
}
li {
  width: 200px;
}
a {
  color: red;
}
#box a:hover {
    color: blue;
}

混合

添加多个样式给一个变量中去使用

.bor {
    background: red;
    border: 2px solid #000;
}
 //想让样式在css中不编译,添加一个()在名字后 例.bor() {...}
#box {
    width: 100px;
    height: 100px;
    .border
}
.div {
    width: 200px;
    height: 200px;
    .border; 
}

显示

#box {
    width: 100px;
    height: 100px;
    background: red;
    border: 2px solid #000;
}
.div {
    width: 200px;
    height: 200px;
    background: red;
    border: 2px solid #000;
}

带参数的混合

.name(@color) {
    border: 1px solid @color;
}
#box {
    .name(red)
}
#box2 {
    .name(blue)
}
#box3 {
    .name(#000)
}

显示

#box {
    border: 1px solid #ff0000;
}
#box2 {
    border: 1px solid #0000ff;
}
#box3 {
     border: 1px solid #000000;
}

带多个参数的混合

**只要给了@属性后, 下面的样式中就必须要添加具体的数值

.name(@w,@color) {
    border: @w solid @color;
}
#box {
    .name(1px,red);
}

div {
  .name(red);
}
//上面的没有给@w数值,2个变量只有1个 就不能显示,所以是错误的
#box2 {
    .name(2px,blue);
}
#box3 {
    .name(@color:#000,@w:3px);
}

显示

#box {
     border: 1px solid #ff0000;
}
#box2 {
    border: 2px solid #0000ff;
}
#box3 {
     border: 3px solid #000000;
}

添加了参数默认值的混合

.name{@w:1px,@color:red} {
    border: @w solid @color;
}
#box {
    .name;
}
#box2 {
    .name()
}
#box3 {
    .name(2px,blue);
}
#box4 {
    .name(@w:2px,@color:yellow);
}
.numble(@x,@y) {
    @name: ((@x+@y) / 2);
}
div {
    .numble(16px,50px);
    padding: @name;
}

结果

#box {
    border: 1px solid #ff0000;
}
#box2 {
    border: 1px solid #ff0000;
}
#box3 {
    border:2px solid #0000ff;
}
#box4 {
    border: 2px solid #ffff00;
}
div {
    padding: 33px;
}

这样Less就可以在多项样式上添加更加方便

.boxS() {
    box-shadow+: 0 0 10px #000;
}
#box {
    .boxS;
    box-shadow+: inset 0 0 10px red;
}

显示

#box {
     box-shadow: 0 0 10px #000, inset 0 0 10px red;
}

混合中的判断

给样式设置条件,只有条件成立后才会识别其中的样式

.width(@w) when (@w >= 200px)
{
  width:@w;
}
#box1 {
    .width(100px);
}
#box2 {
    .width(200px);
}
#box3 {
    .width(300px);
}

在css中显示

#box2 {
  width: 200px;
}
#box3 {
  width: 300px;
}

给出不同的条件下的样式,根据条件成立来选取不同的样式

   .name(@w,@c,@dir) when (@dir = 1)
   { 
    border-top: @w solid @c;
   }
   .name(@w,@c,@dir) when (@dir = 2)
   {
    border-right: @w solid @c;
   }
   .name(@w,@c,@dir) when (@dir = 3)
   {
    border-bottom: @w solid @c;
   }
   .name(@w,@c,@dir) when (@dir = 4)
   {
    border-left: @w solid @c;
   }
   
   #box {
    .name(2px,red,3);
   }

结果

#box {
  border-bottom: 2px solid #ff0000;
}

上面设置不同的变量,当满足变量所要的条件后,就会执行其中的内容。当下面需要变量的样式时,就会找到所含的变量名称后,变量有确定数值的就按照变量走,没有确定数值,就需要自己设置,当对应设置的数值满足上面变量的条件后,就会执行

> < =  >=  <=
.name(@w,@c,@dir) when (判断条件)
{
    //条件成立之后,执行的内容
}
.name(@dir) when (@dir = top)
{
    border-top: 10px solid #000;    
}
.name(@dir) when (@dir = right)
{
    border-right: 10px solid #000;  
}
.name(@dir) when (@dir = bottom)
{
    border-bottom: 10px solid #000;     
}
.name(@dir) when (@dir = left)
{
    border-left: 10px solid #000;   
}
#box {
    .name(left); //找到所有叫 .name()的混合
}


循环

.name(@numble) when (@numble >= 0)
   {
    .name(@numble - 10); //函数调用
    width: @numble; //执行语句
   }
   .box {
    .name(100px);
   }

结果

.box {
  width: 0px;
  width: 10px;
  width: 20px;
  width: 30px;
  width: 40px;
  width: 50px;
  width: 60px;
  width: 70px;
  width: 80px;
  width: 90px;
  width: 100px;
}

从小到大排列 先写函数调用后写执行语句;

函数调用,都是上面的执行完后才会往下执行,当.box给了.name变量的数值为100px往后执行;

满足了when >=0,继续往下执行;

这时.name为100px-10;继续往下width: 就为90px了;

这时 .name(@numble - 10);这一条还没执行完,会继续在条件满足下运行,当最后结果为不小于0后;

就会往下执行width=0了;

然后继续回到上面执行之前的结果,一直到最后为结果显示

从大到小排列 先执行语句后写写函数调用

.name(@numble) when (@numble >= 0)
   {
    width: @numble; //执行语句
    .name(@numble - 10);//函数调用
   }
   .box {
    .name(100px);
   }

结果

.box {
  width: 100px;
  width: 90px;
  width: 80px;
  width: 70px;
  width: 60px;
  width: 50px;
  width: 40px;
  width: 30px;
  width: 20px;
  width: 10px;
  width: 0px;
}

当.box给了最上面.name数值条件得到满足,直接执行width: 为100px了;

然后往下执行,-10后 继续执行width: 90px;...

后面循环 直到最后结果小于0的条件。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336

推荐阅读更多精彩内容