-
Notifications
You must be signed in to change notification settings - Fork 47
Quirks
Mixins parameters are either semicolon or comma separated. It is recommended to use semicolon. Comma as mixins parameters separator is kept only for backward compatibility.
The symbol comma has double meaning: it can be interpreted either as a mixin parameters separator or CSS list separator. Using comma as mixin separator makes it impossible to create comma separated lists as an argument. On the other hand, if the compiler sees at least one semicolon inside a mixin call or declaration, the compiler assumes that arguments are separated by semicolons and all commas belong to css lists:
- two arguments and each contains comma separated list:
.name(1, 2, 3; something, else)
, - three arguments and each contains one number:
.name(1, 2, 3)
, - use dummy semicolon to create mixin call with one argument containing comma separated css list:
.name(1, 2, 3;)
, - comma separated default value:
.name(@param1: red, blue;)
.
Css uses two types of expressions separators: a space (' ') and a comma (','). Comma is not allowed to be inside a parentheses e.g., this something: (12 (13 + 10,-23));
throws compile exception.
However, space is allowed inside the parentheses and is treated the same way as a top level separator. If they contain the empty separator, the output will contain separator too. Parentheses influence the order of arithmetic operations, but the user should be careful about spaces inside them.
Related less.js discussion: https://github.com/cloudhead/less.js/issues/952
Sample input:
parentheses {
something: (12 (13 + 10 -23));
}
Sample output:
parentheses {
something: 12 23 -23;
}
Some more cases:
something: (12 + (13 + 10 -23)); //Compiles into 12
something: (12 * (13 + 5 -23)); //Compiles into NaN
something: (12 (13 + 5 -23) + 5); //Compile error: Object doesn't support this property or method
Less.js adds four arithmetic operations into CSS: addition (+), subtaction (-), multiplication (*) and division (/). You can use spaces inside those expressions e.g., following two expressions are equivalent:
2 + 3 * 4
-
2+3*4
.
This feature interacts with standard CSS in an unfortunate way. CSS declarations use spaces as a separator and they allow also negative values. Correct CSS:
something {
margin: -1 -2 -3 -4;
}
Combination of spaces as separators, negative numbers and expressions causes spaces to be significant. Two expressions with the same numbers and operators may mean two different things. Declarations in following example differ only in spaces, but their meaning is different:
one {
margin: 1 -2; //compiles into "margin: 1 -2;"
}
two {
margin: 1 - 2; //compiles into "margin: -3;"
}
Space is not allowed between function name and parenthesis. This is NOT considered a function: width: increment (15);
and is compiled into width: increment (15);
. The space must be removed e.g., width: increment(15);
compiles to width: 16;
Note: if they less.js would allow a space after the function name, the grammar would become ambiguous. The only way to differentiate between an identifier followed by expression and an function would be to keep a list of allowed functions and restrict those identifiers on anything except them.
The last variable declaration within the same scope wins - less was defined this way so it is consistent with how css behaves. See https://github.com/cloudhead/less.js/issues/297 and https://github.com/cloudhead/less.js/issues/905 issues in less.js project for related discussions.
Sample input:
@var: @a;
@a: 100%;
.lazy-eval {
width: @var;
}
@a: 50%;
.lazy-eval two {
width: @var;
}
Compiles into:
.lazy-eval {
width: 50%;
}
.lazy-eval two {
width: 50%;
}
Note: variables are officially constants and their value should be defined only once. Technically, this should not matter, because the above style sheet is incorrect less. However, judging from the related discussions, it does matter.
Nth expression is not allowed as a variable value. E.g. this is NOT syntactically correct:
@nth:3n+2;
.values:nth-child(@nth) {
declaration:value;
}
Triple variables indirection does not work. E.g. this is NOT syntactically correct:
.variable-names {
@var: 'hello';
@almostthere: 'var';
@name: 'almostthere';
name1: @@almostthere;
name: @@@name;
}
The last line throws the exception. On the other hand, this is OK:
.variable-names {
@var: 'hello';
@almostthere: 'var';
@name: 'almostthere';
name1: @@almostthere;
}
and compiles into:
.variable-names {
name1: 'hello';
}
Less.js reorders statements in @media. It prints declarations first and rulesets second. The last declaration does not have a new line, following ruleset starts at the same line.