当前位置: 首页>前端>正文

css less使用 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;
    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 设置参数:


https://www.xamrdz.com/web/2xc1963470.html

相关文章: