前几日花了一天去看less,这几日在捣鼓其余东西,项目也在有序的进行中,今天花点时间整理下less的基础语法,也分享实际中的一些经验,与众人共享。java
本篇笔者以less的基础语法着手,并配合bootstrap的逻辑结构给你们梳理下less的语法,方便之后实战中快速开发。jquery
1.变量编程
与许多后台编辑语法相似,less也有着本身的变量,不过less中的变量更确切来讲是一种常量,一次赋值永不改变。bootstrap
@font-size:14px;c#
p{font-size:@font-size}less
-->p{font-size:14px}编程语言
前面说过,bootstrap源码的variables.less文件定义了全部的变量,其余组件对应的less文件使用了其定义的变量,方面统一管理。函数
variables.less以下所示,假如咱们想简单的定制bootstrap,修改少量变量定义就能够了。学习
2.注释spa
less的注释与许多后台语言相同。
行注释://xxxx
块注释:/*xxxx
xxxx*/
3.导入
@import "xxx";
@import语法导入其余文件,如定义好的变量,bootstrap就充分的利用了这一点,咱们来看bootstrap.less源码。
bootstrap这个文件前面有说过,引入了全部的less文件,最后直接编译这个文件便可。
看源码就能够看出,首先引用的是variables.less,这是全部变量的定义。
其次引入mixins.less,mixins.less中又导入了全部的混合函数定义,这在后面的组件less中都有用到。
这就至关于c#等后台语言首先导入类库通常。
4.混合
.border{
border:1px solid solid;
}
.header{
height:200px;
.border;
}
-->.header{
border:1px solid solid;
height:200px;
}
混合的最大好处在于你不用一遍又一遍写着重复的样式了,能够随便引用。
5.嵌套
.header{
xxx;
.header-body{
xxx1;
}
.header-footer{
xxx2;
}
&:hover{
xxx3;
}
}
-->
.header{xxx}
.header .header-body{xxx1}
.header .header-footer{xxx2}
.header:hover{xxx3}
聪明的大概能够看出来 '&'的做用了吧,&表明父选择器,至关去jquery中的.parent()方法。
嵌套在bootstrap中随处可见,下面是.btn 按钮样式的示例。
5.媒体查询
bootstrap很成功很大一部分缘由在于其对相应式的支持,而这离不开媒体查询。
@media(min-width>768px){
ssss;
}
@media(min-width>970px){
ssss;
}
grid.less应对不一样屏幕的混合属性也有所不一样。
以下图所示。
6.函数
同全部编程语言相同的是,less也有着本身的函数库。
例如:
darken(@color,@amout)//下降必定数值的色彩亮度
参数:
@color
: 颜色对象(A color object)@amount
: 百分比 0-100%返回值: 颜色(color)
例如bootstrap默认连接hover样式是下降了15%的亮度。
如图所示。
7.运算
任何数值,颜色和变量均可以进行运算。这里有一对示例:
@base: 5%;
@filler: @base * 2;//乘法
@other: @base + @filler;//加法
color: #888 / 4;//除法
background-color: @base-color + #111;
height: 100% / 2 + @filler;//综合运算
less运算的另外一个特色是能够自动推算出单位,这个是不少后台编程语言所没有的特性,值得点赞。
@var: 1px + 5;
在这个例子中 Less 会在最终输出结果中使用这个单位 -- 6px
bootstrap中一个典型的应用就是,各类屏幕终端设备宽度等于定义宽度+网格流宽度,而这个网格流宽度,则会看成左右内边距来使用。
8.命名空间
#bundle {
.button {
display: block; border: 1px solid black; background-color: grey; &:hover { background-color: white }
}
.tab { ... }
.citation { ... }
}
如今咱们想在 #header a
中混合 .button
类。
一些同窗是否是想到了前面说过的混合了呢,可是这里牵扯到命名空间问题,与c#等语言类库中的方法相同,两个类库中可能定义这相同的方法,这个时候就要经过命名空间来区分了,说的又有点向java的打包了。
好吧,这个时候咱们该这么去使用。
#header a {
color: orange;
#bundle > .button;
}
9.做用域
这个至关于c#之类语言中的成员变量和局部变量了,熟悉之类语言的能够跳过这个知识点了。
@var: red;
#page {
@var: white;
#header {
color: @var; // 这个时候#header 的color属性是white
}
}
在bootstrap中经常使用的大概是1--7点,后面两点有点鸡肋。
固然这9点只是less最基础的语法,若是想凭这些去定制比较好的bootstrap主题仍是不够的,可是基础简单的修改仍是能够驾轻就熟了。
晚上运动点有点大,天气热的很,熬到这个点有点小累了,因此有些例子用了官方的例子,抱歉。
预祝你们能够玩的愉快,学习的愉快。