-
Notifications
You must be signed in to change notification settings - Fork 0
Home
Welcome to the less.js wiki!
As an extension to CSS, LESS is not only backwards compatible with CSS, but the extra features it adds use existing CSS syntax. This makes learning LESS a breeze, and if in doubt, lets you fall back to CSS.
These are pretty self-explanatory:
@nice-blue: #5B83AD;
@light-blue: @nice-blue + #111;
#header { color: @light-blue; }
Outputs:
#header { color: #6c94be; }
Note that variables are actually 'constants' in that they can only be defined once.
Mixins are a way of including ('mixing in') a bunch of properties from one rule-set into another rule-set. So say we have the following class:
.bordered {
border-top: dotted 1px black;
border-bottom: solid 2px black;
}
And we want to use these properties inside other rule-sets. Well, we just have to drop in the name of the class where we want the properties, like so:
#menu a {
color: #111;
.bordered;
}
.post a {
color: red;
.bordered;
}
The properties of the .bordered
class will now appear in both #menu a
and .post a
. (Note that you can also use #ids
as mixins.)
LESS gives you the ability to use nesting instead of, or in combination with cascading. Let's say we have the following CSS:
#header { color: black; }
#header .navigation {
font-size: 12px;
}
#header .logo {
width: 300px;
}
In LESS, we can also write it this way:
#header {
color: black;
.navigation {
font-size: 12px;
}
.logo {
width: 300px;
}
}
The resulting code is more concise, and mimics the structure of your HTML.
You can also bundle pseudo-selectors with your mixins using this method. Here's the classic clearfix hack, rewritten as a mixin (&
represents the current selector parent):
.clearfix {
display: block;
zoom: 1;
&:after {
content: " ";
display: block;
font-size: 0;
height: 0;
clear: both;
visibility: hidden;
}
}
Any number, color or variable can be operated on. Here are a couple of examples:
@base: 5%;
@filler: @base * 2;
@other: @base + @filler;
color: #888 / 4;
background-color: @base-color + #111;
height: 100% / 2 + @filler;
The output is pretty much what you expect—LESS understands the difference between colors and units. If a unit is used in an operation, like in:
@var: 1px + 5;
LESS will use that unit for the final output—6px
in this case.
Sometimes, you may want to group your variables or mixins, for organizational purposes, or just to offer some encapsulation. You can do this pretty intuitively in LESS—say you want to bundle some mixins and variables under #bundle
, for later reuse or distributing:
#bundle {
.button {
display: block;
border: 1px solid black;
background-color: grey;
:hover { background-color: white }
}
.tab { ... }
.citation { ... }
}
Now if we want to mixin the .button
class in our #header a
, we can do:
#header a {
color: orange;
#bundle > .button;
}
LESS also allows you to access specific properties or variables from different rule-sets:
#defaults {
@width: 960px;
@color: black;
}
.article { color: #294366; }
.comment {
width: #defaults[@width];
color: .article['color'];
}
Variables and accessors can be used almost interchangeably, use whichever is best suited for the situation. Accessors might make more sense if that property only needs to be accessed once.
Scope in LESS is very similar to that of programming languages. Variables and mixins are first looked for locally, and if they aren't found, the compiler will look in the parent scope, and so on.
Note that the order of declaration does matter.
@var: red;
#page {
@var: white;
#header {
color: @var; // white
}
}
Both C-style and inline comments are authorized:
/* One hell of a comment */
@var: red;
// Get in line!
@var: white;
Importing works pretty much as expected. You can import a .less
file, and all the variables in it will be available. If the file is a .less
, the extension is optional:
@import "library";
@import "typo.css";
LESS is a pretty concise language. :-)