(一)嵌套规则

  【1】less可以让我们以嵌套的方式编写层叠样式,先看下面这段CSS;

.box-a .hd {
height: 20px;
}
.box-a .bd .txt {
color: #000;
}
.box-a .other {
position: relative;

  在LESS中,可以用嵌套方式写以上代码:

.box-a{
.hd{
height:20px;
}
.bd{
.txt{
color:#000;
}
}
.other{
position:relative;
}
}

  代码变更简洁与直观,与DOM树结构很相似。

  【2】 & 符号

  如果在嵌套规则中,想写串联选择器,而不是写后代选择器,可以用 & 符号,如:hover 伪类写法

.box-a{
.hd{
height:20px;
a{
&:hover{
color:#000;
}
}
} }

  编译后:

.box-a .hd {
height: 20px;
}
.box-a .hd a:hover {
color: #000;
}

(二)变量

  【1】定义

  @名:值; (需要在末尾加上分号)

@color:#f60;
p{
background-color:@color;
}

  编译后:

p {
background-color: #ff6600;
}

  【2】字符串插入变量值

@url:'../images/';
p{
background:url('@{url}sp.png');

  编译后:

p {
background: url('../images/sp.png');
}

  【3】变量之间赋值

@url:'../images/';
@pageurl:@url; p{
background-image:url('@{pageurl}xxxx.jpg');
}

  编译后:

p {
background-image: url('../images/xxxx.jpg');
}

  【4】预解析

  (1)Less的变量调用,不需要在变量声明后才可以使用;

  (2)同一个变量定义多次,在当前作用域中最后一次定义的将被使用

p{
background-image:url('@{url}xxxx.jpg');
} @url:'../images/';
@url:'http://www.xx.com/';

  编译后:

p {
background-image: url('http://www.xx.com/xxxx.jpg');
}

(三)混合(Mixins)

  【1】调用已有的class或id 属性集  

#modA{color:#000;}
.fl{float:left;} p{
#modA;
.fl;
}

  编译后:

#modA {
color: #000;
}
.fl {
float: left;
}
p {
color: #000;
float: left;
}

  【2】带参数(或者空参数)的混合,编译后不会暴露在css文件中

#modA(){color:#000;}
.fl(){float:left;} p{
#modA;
.fl;
}

  编译后(CSS文件没有混合模块的代码):

p {
color: #000;
float: left;
}

  

  【3】设置默认参数

.mixins(@w;@h:100px){
width:@w;
height:@h;
}
p{
.mixins(50px);
}

  编译后:

p {
width: 50px;
height: 100px;
}

  【4】参数

  (1)多个参数可以使用分号或者逗号分隔,推荐使用分号分隔,因为逗号有两重含义:它既可以表示混合的参数,也可以表示一个参数中一组值的分隔符。

  (2)如果在混合的定义或者是调用中找到至少一个分号,就会假设参数是使用分号分隔的,所有的逗号都属于参数中的一组值的分隔符。

.mixins(@font;@h){
font:@font;
height:@h;
}
p{
.mixins(12px 'Microsoft yahei',arial;50px);
}

  编译后:

p {
font: 12px 'Microsoft yahei', arial;
height: 50px;
}  

  (3)...  设置不限制参数的个数;@arguments 获取全部的参数值

.mixins(...){
-webkit-transform:@arguments;
-moz-transform:@arguments;
-ms-transform:@arguments;
-o-transform:@arguments;
transform:@arguments; }
p{
.mixins(translate(-10px,-10px));
}

  编译后:

p {
-webkit-transform: translate(-10px, -10px);
-moz-transform: translate(-10px, -10px);
-ms-transform: translate(-10px, -10px);
-o-transform: translate(-10px, -10px);
transform: translate(-10px, -10px);
}

  【5】同名混合不会覆盖,符合且都会调用

.mixins(){
overflow:hidden;
}
.mixins(){
font:;
}
p{
.mixins();
}

  编译后:

p {
overflow: hidden;
font:;
}

  【6】匹配

  (1)根据参数数量匹配

.mixins(){
overflow:hidden;
}
.mixins(@fz){
font:@fz;
}
.mixins(@w;@h){
width:@w;
height:@h;
}
p{
.mixins(10px);
}

  编译后:

p {
font: 10px;
}

  (2)指定匹配

.mixins(baidu){
overflow:hidden;
}
.mixins(winds){
font-size:;
} p{
.mixins(baidu);
}

  编译后:

p {
overflow: hidden;
}

  【7】表达式匹配 Guards,支持的表达式匹配运算符包括:>   >=   =    =<    <   (注意:相等是 = )

  (1)单个条件

.mixins(@type) when(@type=baidu){
overflow:hidden;
} .mixins(@type) when(@type=winds){
font-size:;
} p{
.mixins(baidu);
}

  编译后:

p {
overflow: hidden;
}

  (2)多条件,用逗号隔开:符合其中之一即可匹配

.mixins(@type) when(@type=baidu),(@type=winds){
overflow:hidden;
} p{
.mixins(baidu);
} h1{
.mixins(winds);
}

  编译后:

p {
overflow: hidden;
}
h1 {
overflow: hidden;
}

  (3)多条件,用 and 隔开:全部符合才匹配

.mixins(@type;@style) when(@type=baidu)and(@style=blue){
overflow:hidden;
} p{
.mixins(baidu;blue);
} h1{
.mixins(baidu;pink);
}

  编译后:

p {
overflow: hidden;
}

(四)递归 

  可以在定义的混合模块自我调用(递归)

  循环输出的例子

.loop(@n;@i:1) when(@i<=@n){
.row-@{i}{
background:url('xxx.jpg') 0 @i*10px no-repeat;
} .loop(@n;(@i+1));
} .bg{
.loop(5);
}

  编译后:

.bg .row-1 {
background: url('xxx.jpg') 0 10px no-repeat;
}
.bg .row-2 {
background: url('xxx.jpg') 0 20px no-repeat;
}
.bg .row-3 {
background: url('xxx.jpg') 0 30px no-repeat;
}
.bg .row-4 {
background: url('xxx.jpg') 0 40px no-repeat;
}
.bg .row-5 {
background: url('xxx.jpg') 0 50px no-repeat;
}

(五)作用域

  作用域跟其他编程语言类似,首先会从本地查找变量或者混合模块,如果没找到的话会去父级作用域中查找,逐层递增,直到找到为止,否则报错。

@color:#f60;

p{
@color:#333;
background-color:@color;
}

  编译后:

p {
background-color: #333333;
}

(六)命名空间

  为了更好组织 CSS 或者单纯是为了更好的封装,可以添加命名空间

.index{
.mixins(){
font-size:;
}
} p{
.index > .mixins();
}

  编译后:

p {
font-size:;
}

(七)注释

   /*编译后保留css原有注释*/

  // 同时支持双反斜杠,但编译后不会保留在css文件中

(八)导入(import)

  其实就是把样式内嵌到指定的文件中,不会带来额外请求

  (1)嵌入less文件

@import "layout.less";

  (2)嵌入css文件

@import (inline) "base.css";

(八)避免编译

  如果需要输出一些不正确的 CSS 语法或者使用一些 LESS 不认识的专有语法,编译为less文件过程中会出现错误,这时候可以用避免编译来处理。

  要输出这样的值我们可以在字符串前加上一个 ~

  看下出错的例子:

p{
_top:expression(eval(document.documentElement.scrollTop));

  编译过程中报错

  所以需要用到避免编译的语法

p{
_top:~"expression(eval(document.documentElement.scrollTop))";
}

  避免编译也支持字符串插入值

@opacity:50;
p{
opacity:50/100;
filter:~"alpha(opacity=@{opacity})";
}

  编译后:

p {
opacity: 0.5;
filter: alpha(opacity=50);
}

  总结:以上只是less知识中的冰山一角,更多请关注官网 http://www.lesscss.net/article/home.html

  下一章是  less代码跟踪调试  敬请期待

Less开发指南(二)- 基本语法的更多相关文章

  1. Spark Streaming和Kafka整合开发指南(二)

    在本博客的<Spark Streaming和Kafka整合开发指南(一)>文章中介绍了如何使用基于Receiver的方法使用Spark Streaming从Kafka中接收数据.本文将介绍 ...

  2. 【转】Polymer API开发指南 (二)(翻译)

    原文转自:http://segmentfault.com/blog/windwhinny/1190000000596258 公开 property 当你公开一个 Polymer 元素的 propert ...

  3. Polymer API开发指南 (二)(翻译)

    公开 property 当你公开一个 Polymer 元素的 property 名字时,就等于把这个 property 设置为公开API了.公开 property 会有如下的特性: 支持声明数据双向绑 ...

  4. ECMALL模板解析机制.MVC架构分析及文件目录说明.二次开发指南手册(转)

    ECMALL模板解析语法与机制 http://www.nowamagic.net/architecture/archt_TemplateSyntaxAndAnalysis.php ECMALL模块开发 ...

  5. 现代前端库开发指南系列(二):使用 webpack 构建一个库

    前言 在前文中,我说过本系列文章的受众是在现代前端体系下能够熟练编写业务代码的同学,因此本文在介绍 webpack 配置时,仅提及构建一个库所特有的配置,其余配置请参考 webpack 官方文档. 输 ...

  6. ECSHOP二次开发指南

    ECSHOP二次开发指南 发布时间:2013-05-28 12:47:00   来源:   评论:0 点击: 次 [字号:大 中 小] QQ空间新浪微博腾讯微博人人网豆瓣网百度空间百度搜藏开心网复制更 ...

  7. Knockout应用开发指南 第三章:绑定语法(3)

    原文:Knockout应用开发指南 第三章:绑定语法(3) 12   value 绑定 目的 value绑定是关联DOM元素的值到view model的属性上.主要是用在表单控件<input&g ...

  8. Knockout应用开发指南 第三章:绑定语法(2)

    原文:Knockout应用开发指南 第三章:绑定语法(2) 7   click 绑定 目的 click绑定在DOM元素上添加事件句柄以便元素被点击的时候执行定义的JavaScript 函数.大部分是用 ...

  9. Knockout应用开发指南 第三章:绑定语法(1)

    原文:Knockout应用开发指南 第三章:绑定语法(1) 第三章所有代码都需要启用KO的ko.applyBindings(viewModel);功能,才能使代码生效,为了节约篇幅,所有例子均省略了此 ...

  10. App架构师实践指南二之App开发工具

    App架构师实践指南二之App开发工具     1.Android Studio 2.编译调试---条件断点.右键单击断点,在弹出的窗口中输入Condition条件.---日志断点.右键单击断点,在弹 ...

随机推荐

  1. 关于/proc/进程idpid/fd ,根据fd来查找连接

    当创建好epoll句柄后,它就是会占用一个fd值,在linux下如果查看/proc/进程id/fd/,是能够看到这个fd的,所以在使用完epoll后,必须调用close()关闭,否则可能导致fd被耗尽 ...

  2. boost::any 用法

    boost::any可以存放任何类型的C++类型,也可以是用户自定义的类型.非常方便,可以很方便的满足在运行过程中判断数据类型,从而进行相关的操作. 函数原型: // In header: <b ...

  3. 10、property

    成人的BMI数值:过轻:低于18.5正常:18.5-23.9过重:24-27肥胖:28-32非常肥胖, 高于32 体质指数(BMI)=体重(kg)÷身高^2(m) EX:70kg÷(1.75×1.75 ...

  4. Git-从远程仓库克隆

    本人拜读了廖雪峰老师关于Git的讲述后整理所得 上次我们讲了先有本地库,后有远程库的时候,如何关联远程库. 现在,假设我们从零开发,那么最好的方式是先创建远程库,然后,从远程库克隆. 首先,登陆Git ...

  5. 端口状态说明 LISTENING、ESTABLISHED、TIME_WAIT及CLOSE_WAIT

    TCP状态转移要点    TCP协议规定,对于已经建立的连接,网络双方要进行四次握手才能成功断开连接,如果缺少了其中某个步骤,将会使连接处于假死状态,连接本身占用的资源不会被释放.网络服务器程序要同时 ...

  6. 并发队列ConcurrentLinkedQueue与阻塞队列LinkedBlockingQueue的区别

    1.  介绍背景 在Java多线程应用中,队列的使用率很高,多数生产消费模型的首选数据结构就是队列. Java提供的线程安全的Queue可以分为阻塞队列和非阻塞队列,其中阻塞队列的典型例子是Block ...

  7. 如何释放linux cache占用的内存

    [root@prd-fygl-app-01 ~]# free -m             total       used       free     shared    buffers     ...

  8. 为什么iterator,foreach遍历时不能进行remove操作?除了一种情况可以这样(特殊情况)?

    Exception in thread "main" java.util.ConcurrentModificationException 并发修改异常引发的思考! 1 foreac ...

  9. 在linux环境下安装python3.6

    wget https://www.python.org/ftp/python/3.6.1/Python-3.6.1.tgz --no-check-certificat gunzip Python-3. ...

  10. 20135320赵瀚青LINUX第十八章读书笔记

    概述:调试工作艰难是内核级开发区别于用户级开发的一个显著特点 18.1准备开始 内核调试往往是一个令人挠头不已的漫长过程.幸运的是,在这些费劲的问题中也有不少比较简单而且容易消灭的小bug,运气好你可 ...