CSS语言扩展-Less

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;
     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 { (1 + 1) }', function (e, css) {
console.log(css);
});
输出为

.class {
2;
}
你还可以手动调用分析器(paser)和编译器:

var parser = new(less.Parser);

parser.parse('.class { (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 { (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 设置参数:

原文地址:https://www.cnblogs.com/Jiazexin/p/7080138.html