一、入门

1、LESSCSS是什么?

LESSCSS是一种动态样式语言,属于CSS预处理语言的一种,它使用类似CSS的语法,为CSS的赋予了动态语言的特性,如变量、继承、运算、函数等,更方便CSS的编写和维护。

LESSCSS可以在多种语言、环境中使用,包括浏览器端(支持IE6+, Webkit, Firefox)、桌面客户端、服务端。

例如:

@color:#4D926F;
p{
color: @color;
}

编译成:

p{
color: #4D926F;
}

2、使用LESSCSS

1)客户端使用

在浏览器中使用less.js是非常方便的,但是这种方式不建议用于生产。在生产中,建议使用node.js或者第三方工具进行预编译。

首先,链接.less文件,设置rel属性为"stylesheet/less":

<link rel="stylesheet/less" type="text/css" href="styles.less" />

接着,下载less.js,或者到官网下载最新的,包含在<script></script>标签中:

<script src="less.js" type="text/javascript"></script>

也可以使用Less CDN:

<script src="//cdnjs.cloudflare.com/ajax/libs/less.js/2.5.3/less.min.js"></script>

在 <script src="less.js"></script> 之前设置全局的的less对象:

<!-- set options before less.js script -->
<script>
less = {
env: "development",
async: false,
fileAsync: false,
poll: 1000,
functions: {},
dumpLineNumbers: "comments",
relativeUrls: false,
rootpath: ":/a.com/"
};
</script>
<script src="less.js"></script>

意:确保在引用脚本之前引用样式文件。

点击以下链接下载上述代码:LESSCSS入门demo

二、语法特性

1、变量(Variables)

变量允许我们单独定义一系列通用的样式,然后在需要的时候去调用。所以在做全局样式调整的时候我们可能只需要修改几行代码就可以了。

例如:

@nice-blue: #5B83AD;
@light-blue: @nice-blue + #111; #header {
color: @light-blue;
}

输出:

#header {
color: #6c94be;
}

注意:这里的变量实际上是常量。

变量也可以用于选择器名称、属性名、URL和 @import 声明。

1)选择器名称

例如:

// Variables
@my-selector: banner; // Usage
.@{my-selector} {
font-weight: bold;
line-height: 40px;
margin: 0 auto;

输出:

.banner {
font-weight: bold;
line-height: 40px;
margin: 0 auto;
}

2)属性名

例如:

@property: color;

.widget {
@{property}: #0ee;
background-@{property}: #999;

输出:

.widget {
color: #0ee;
background-color: #999;

3)变量名

例如:

@fnord:  "I am fnord.";
@var: "fnord";
content: @@var;

输出:

content: "I am fnord.";

4)URL

例如:

// Variables
@images: "../img"; // Usage
body {
color: #444;
background: url("@{images}/white-sand.png");

5)导入声明

例如:

// Variables
@themes: "../../src/themes"; // Usage
@import "@{themes}/tidal-wave.less"; 

变量是懒加载的,不是必须在使用前声明,可以在使用后声明。例如:

.lazy-eval {
width: @var;
} @var: @a;
@a: 9%;

2、混合(Mixins)

混合可以将一个定义好的class A轻松的引入到另一个class B中,从而简单实现class B继承class A中的所有属性。我们还可以带参数地调用,就像使用函数一样。

例如:

.bordered {
border-top: dotted 1px black;
border-bottom: solid 2px black;
}
#menu a {
color: #111;
.bordered;
}
.post a {
color: red;
.bordered;
}  

输出:

.bordered {
border-top: dotted 1px black;
border-bottom: solid 2px black;
}
#menu a {
color: #111;
border-top: dotted 1px black;
border-bottom: solid 2px black;
}
.post a {
color: red;
border-top: dotted 1px black;
border-bottom: solid 2px black;
}

1)不输出mixin

可以在mixin后面添加"()"括号,让其不输出。

例如:

.my-mixin {
color: black;
}
.my-other-mixin() {
background: white;
}
.class {
.my-mixin;
.my-other-mixin;
}

输出:

.my-mixin {
color: black;
}
.class {
color: black;
background: white;
}

2) !important 关键字

在mixin后面使用 !important 关键字,那么继承的所有属性都会加上 !important 。

例如:

.foo (@bg: #f5f5f5, @color: #900) {
background: @bg;
color: @color;
}
.unimportant {
.foo();
}
.important {
.foo() !important;
}

输出:

.unimportant {
background: #f5f5f5;
color: #900;
}
.important {
background: #f5f5f5 !important;
color: #900 !important;

3)可以传递参数的Mixins

例如:

.border-radius(@radius) {
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
border-radius: @radius;
}
#header {
.border-radius(4px);
}
.button {
.border-radius(6px);

输出:

#header {
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
}
.button {
-webkit-border-radius: 6px;
-moz-border-radius: 6px;
border-radius: 6px;
}

也可以设置参数默认值。例如:

.border-radius(@radius: 5px) {
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
border-radius: @radius;
}
#header {
.border-radius;
}

输出:

header {
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;

3、嵌套(Nested Rules)

可以在一个选择器中嵌套另一个选择器来实现继承。

例如:

#header {
color: black;
}
#header .navigation {
font-size: 12px;
}
#header .logo {
width: 300px;
}  

可以写成:

#header {
color: black;
.navigation {
font-size: 12px;
}
.logo {
width: 300px;
}
}  

例如:

.clearfix {
display: block;
zoom:; &:after {
content: " ";
display: block;
font-size:;
height:;
clear: both;
visibility: hidden;
}

其中,&当前选择器的父元素。

4、运算符(Operations)

运算提供了加,减,乘,除操作;我们可以做属性值和颜色的运算,这样就可以实现属性值之间的复杂关系。

例如:

// numbers are converted into the same units
@conversion-1: 5cm + 10mm; // result is 6cm
@conversion-2: 2 - 3cm - 5mm; // result is 1.5cm // conversion is impossible
@incompatible-units: 2 + 5px - 3cm; // result is 4px // example with variables
@base: 5%;
@filler: @base * 2; // result is 10%
@other: @base + @filler; // result is 15% @color: #224488 / 2; //results in #112244
background-color: #112244 + #111; // result is #223355

5、转码(Escaping)

转码允许你使用任意的字符串作为属性或变量值。格式: ~"anything" 或 ~'anything' 。

例如:

.weird-element {
content: ~"^//* some horrible but needed css hack";
}

输出:

.weird-element {
content: ^//* some horrible but needed css hack;
}

6、函数(Functions)

Less提供了大量的函数用于转换颜色、处理字符串和数学运算。

例如:

@base: #f04615;
@width: 0.5; .class {
width: percentage(@width); // returns `50%`
color: saturate(@base, 5%);
background-color: spin(lighten(@base, 25%), 8);
}

输出:

.class {
width: 50%;
color: #f6430f;
background-color: #f8b38d;
}

7、Namespaces adn Accessors

例如:

#bundle {
.button {
display: block;
border: 1px solid black;
background-color: grey;
&:hover {
background-color: white
}
}
} #header a {
color: orange;
#bundle > .button;
}

输出:

#bundle .button {
display: block;
border: 1px solid black;
background-color: grey;
}
#bundle .button:hover {
background-color: white;
}
#header a {
color: orange;
display: block;
border: 1px solid black;
background-color: grey;
}
#header a:hover {
background-color: white;
}

8、作用域(Scope)

例如:

@var: red;

#page {
@var: white;
#header {
color: @var; // white
}

变量并不是必须在使用前声明,例如:

@var: red;

#page {
#header {
color: @var; // white
}
@var: white;

9、注释(Comments)

和CSS一样,支持单行"//"和多行注释"/**/"。

例如:

/* One hell of a block
style comment! */
@var: red; // Get in line!
@var: white; 

10、导入(Importing)

支持导入 .css 文件,并且也支持导入 .less 文件(将导入其中定义的所有变量)。

例如:

@import "library"; // library.less
@import "typo.css"; 

11、扩展(Extend)

例1:

.animal {
background-color: black;
color: white;
}
.bear {
&:extend(.animal);
background-color: brown;

输出:

.animal,
.bear {
background-color: black;
color: white;
}
.bear {
background-color: brown;

可以减少CSS的长度,例2:

.my-inline-block {
display: inline-block;
font-size:;
}
.thing1 {
&:extend(.my-inline-block);
}
.thing2 {
&:extend(.my-inline-block);
}

输出:

.my-inline-block,
.thing1,
.thing2 {
display: inline-block;
font-size:;
}

三、相关学习网站

LESS在线编辑器

官方英文学习网站

Bootstrap中文网提供的学习网站

LESSCSS中文官网

CSS预处理器——Sass、LESS和Stylus实践

LessCss学习笔记的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  3. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  4. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  5. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  6. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

  7. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

  8. HTML学习笔记

    HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...

  9. DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记

    今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...

随机推荐

  1. slim.flatten——将输入扁平化但保留batch_size,假设第一维是batch

    slim.flatten(inputs,outputs_collections=None,scope=None) (注:import tensorflow.contrib.slim as slim) ...

  2. centos服务器安装配置Postgre9.6

    安装: STEP1:下载对应rpm yum install https://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-6-x86_64 ...

  3. Swift Optional Chaining

    Optional Chaining介绍 关于「optional chaining」,<The Swift Programming Language>是这么描述的: Optional cha ...

  4. UOJ309 UNR #2 排兵布阵

    包含不小于$\sqrt n$列的只有不大于$\sqrt n$行,修改时这些行打标记,否则暴力更新,操作一列的时候暴力更新这些行.合并没啥影响直接搞就是了.更新需要访问位置,感觉必须用哈希表,并不是特别 ...

  5. 「LuoguP1430」 序列取数(区间dp

    题目描述 给定一个长为n的整数序列(n<=1000),由A和B轮流取数(A先取).每个人可从序列的左端或右端取若干个数(至少一个),但不能两端都取.所有数都被取走后,两人分别统计所取数的和作为各 ...

  6. 洛谷 P4660 & bzoj 1168 [ Baltic OI 2008 ] 手套 —— 分析+单调栈

    题目:https://www.luogu.org/record/show?rid=12702916 https://www.lydsy.com/JudgeOnline/problem.php?id=1 ...

  7. IOS造成卡顿的主要原因

    1. cellForRowAtIndexPath, 单元格视图重用, 注意尽量让所有视图重用, 只根据单元格row和section的不容更换不同的数据, 而不是每次都生成新的单元格, 这是程序奔溃的前 ...

  8. aidl笔记 2/5/2015

    interface Test { //测试的接口 void fun();} Stub 是一个Binderclass Stub extend Binder implements Test { publi ...

  9. CodeForces 1098F. Ж-function

    题目简述:给定字符串$s[1 \dots n](n \leq 2 \times 10^5)$,以及$Q \leq 2 \times 10^5$个询问,每个询问有两个参数$1 \leq l \leq r ...

  10. HTML学习笔记(五)框架

    框架 通过使用框架,可以在同一个浏览器窗口中显示多个页面. eg: <frameset rows="50%,50%"> <frame src="/exa ...