Less 是一门 CSS 预处理语言,它扩展了 CSS 语言,增加了变量、Mixin、函数等特性,使 CSS 更易维护和扩展。
Less 可以运行在 Node 或浏览器端。
例如:
@base: #f938ab;
.box-shadow(@style, @c) when (iscolor(@c)) {
-webkit-box-shadow: @style @c;
box-shadow: @style @c;
}
.box-shadow(@style, @alpha: 50%) when (isnumber(@alpha)) {
.box-shadow(@style, rgba(0, 0, 0, @alpha));
}
.box {
color: saturate(@base, 5%);
border-color: lighten(@base, 30%);
div { .box-shadow(0 0 5px, 30%) }
}
编译为:
.box {
color: #fe33ac;
border-color: #fdcdea;
}
.box div {
-webkit-box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
}
less也是来写样式的跟css一样都是实现样式的
写法,只不过语法不同,它涵盖了一些JS的思想
变量
在JS中var color="#ff6700";
在less中变量前面加上@
@color:#ff6700;
.box1{
color: @color;
}
还可以 以变量的名定义定义为变量
@word:"I love you";
@c:#ff5700;
@var:"word";
定义了一个变量var赋值为一个变量名word
@col:"c";
定义了一个变量var赋值为一个变量名c
#p1:after{
//content: @word;
content: @@var;//@(@var)->@word->"I love you"
color: @@col;
}
混合类
.class1{
font-size: 20px;
width: 200px;
height: 50px;
border: 1px solid red;
}
.box1{
.class1;
background-color: #0000FF;
}
带参数混合
//在less中可以像JS函数一样定义一个带参数的属性集合
.radius(@rad){
border-radius: @rad;
-webkit-border-radius: @rad;
-moz-border-radius: @rad;
-ms-border-radius: @rad;
-o-border-radius: @rad;
}
.box1{
.radius(10px);//@rad=10px;
border: 1px solid #0000FF;
}
//给参数赋默认值
.font(@size:18px){
font-size:@size ;
}
.menu li{
.font();
}
使用 Less
Less 可以通过 npm 在命令行上运行;在浏览器上作为脚本文件下载;或者集成在广大的第三方工具内。请参考 用法 。 安装 在服务器端最容易的安装方式就是通过 npm (node.js 的包管理器),方法如下:
$ npm install -g less
命令行用法
安装 Less 后,就可以在命令行上调用 Less 编译器了,如下:
$ lessc styles.less
这将输出编译之后的 CSS 代码到 stdout,你可以将输出重定向到一个文件:
$ lessc styles.less > styles.css
若要输出压缩过的 CSS,只需添加 -x 选项。如果希望获得更好的压缩效果,还可以通过 --clean-css 选项启用 Clean CSS 进行压缩。
执行 lessc 且不带任何参数,就会在命令行上输出所有可用选项的列表。
在代码中调用 Less
可以像下面这样在代码中调用 Less 编译器(Node 平台)。
var less = require('less');
less.render('.class { width: (1 + 1) }', function (e, css) {
console.log(css);
});
输出为
.class {
width: 2;
}
你还可以手动调用分析器(paser)和编译器:
var parser = new(less.Parser);
parser.parse('.class { width: (1 + 1) }', function (err, tree) {
if (err) {
return console.error(err)
}
console.log(tree.toCSS());
});
配置
可以给编译器传递多个参数:
var parser = new(less.Parser)({
paths: ['.', './lib'], // Specify search paths for @import directives
filename: 'style.less' // Specify a filename, for better error messages
});parser.parse('.class { width: (1 + 1) }', function (e, tree) {
tree.toCSS({
// Minify CSS output
compress: true
});
});
Grunt
Less 还和流行的 Grunt 构建工具进行了集成,可以参考 grunt-contrib-less 插件。
第三方工具
请参考 用法 一节了解其它工具的细节。
客户端用法
在浏览器上跑 less.js 非常方便开发,但是不推荐用于生产环境。
在客户端使用 Less.js 是最容易的方式,并且在开发阶段很方便,但是,在生产环境中,性能和可靠性非常重要,我们建议最好使用 node.js 或其它第三方工具进行预编译。
那就开始吧,在页面中加入 .less 样式表的链接,并将 rel 属性设置为 "stylesheet/less":
接下来,下载 less.js 并通过 标签将其引入,放置于页面的
元素内:
提示
务必确保在 less.js 之前加载你的样式表。
如果加载多个 .less 样式表文件,每个文件都会被单独编译。因此,一个文件中所定义的任何变量、mixin 或命名空间都无法在其它文件中访问。
浏览器端设置参数
在 之前 定义全局的 less 对象就可以为 Less.js 设置参数: