本文整理自:Less:优雅的写css代码javascript
原文写的很好,也很清晰,本文为我的整理方便我的对知识进行汇总整理!(我的建议原地址博文)php
css是不可以定义变量的,也不能嵌套。它没有编程语言的特性。在项目开发中,经常发现有不少css代码是相同的,但咱们一般都是复制而后粘贴。css
举个例子:假设h5应用里主题色是#FF3A6D
,可能用于文字或者背景色。一般开发中,哪里须要这个颜色,咱们就复制这个颜色并粘贴。下次要修改就得所有查找批量替换,其实不是很方便。html
本文即将介绍的less将让咱们更快更方便的编写css代码。前端
Less 是一门 CSS 预处理语言,它扩充了 CSS 语言,增长了诸如变量、混合(mixin)、函数等功能,让 CSS 更易维护、方便制做主题、扩充。java
less使用.less
做为文件后缀。经过第三方工具,能够一键或者实时编译成对应的css文件。node
示例:
demo.lesspython
@base: #f938ab;/*定义变量*/ .box { color: @base; border-color: lighten(@base, 30%); /*使用函数*/ /*嵌套*/ &-content{ width:100%; } .title{ color:#ccc; } }
经过第三方工具,编译后生成:
demo.csslinux
.box { color: #f938ab; border-color: #fdcdea; } .box-content { width: 100%; } .box .title { color: #ccc; }
实际项目中,咱们编辑的是.less
文件,但引用时依旧像往常同样引用.css
文件。经过第三方工具(例如Koala),能够实现.less
文件一发生改变,就生成同名的.css
文件。后文有介绍,等不及的同窗能够先去看看怎么编译成css文件,再返回来看less相关特性和例子。nginx
因为less文件自己就是文本,因此不用特别安装什么编辑器,一般的代码编辑器都能进行编辑。推荐使用sublime text
(建议安装插件Less
,以支持less语法高亮)。
使用@
符号定义。例如:
@base: #f938ab; .box { color: @base; /*变量引用*/ }
变量的做用就是把值定义在一个地方(或一个文件里,经过@import
导入),而后在各处使用,这样能让代码更易维护。
变量也支持URLs:
// Variables @images: "../img"; // 用法 body { color: #444; background: url("@{images}/white-sand.png"); }
属性也支持变量的形式:
@property: color; .widget { @{property}: #0ee; background-@{property}: #999; }
混合就是前面定义的一个样式,后文能够直接引用。示例:
@base: #f938ab; .ellipsis_txt { display: -webkit-box; -webkit-line-clamp: 2; overflow: hidden; word-break: break-all; text-overflow: ellipsis; -webkit-box-orient: vertical; } .box { color: @base; .ellipsis_txt; /*或者 .ellipsis_txt(); */ }
括号是可选的。
能够在一个css里有多个css块,以方便咱们更好的组织代码,编写css模板。
#header { color: black; .navigation { font-size: 12px; } .logo { width: 300px; } }
生成:
#header { color: black; } #header .navigation { font-size: 12px; } #header .logo { width: 300px; }
还支持&
符号:
#header { color: black; &-navigation { font-size: 12px; } &-logo { width: 300px; } &:hover{ color:#ccc; } }
生成:
#header { color: black; } #header-navigation { font-size: 12px; } #header-logo { width: 300px; } #header:hover { color: #ccc; }
任何数字、颜色或者变量均可以参与运算。下面是一组案例:
@base: 5%; @filler: @base * 2; @other: @base + @filler; color: #888 / 4; background-color: @base-color + #111; height: 100% / 2 + @filler;
示例:
@var: 1px + 5; div{ width:@var; }
输出:
div { width: 6px; }
Less 内置了多种函数用于转换颜色、处理字符串、算术运算等。这些函数在函数手册中有详细介绍。
函数的用法很是简单。下面这个例子将介绍如何将 0.5 转换为 50%,将颜色饱和度增长 5%,以及颜色亮度下降 25% 而且色相值增长 8 等用法:
@base: #f04615; @width: 0.5; .class { width: percentage(@width); // returns `50%` color: saturate(@base, 5%); background-color: spin(lighten(@base, 25%), 8); }
编译生成:
.class { width: 50%; color: #f6430f; background-color: #f8b38d; }
有时候,你可能为了更好组织 CSS 或者单纯是为了更好的封装,将一些变量或者混合模块打包起来,一些属性集以后能够重复使用。
示例:
/*模块*/ #bundle { .button { display: block; border: 1px solid black; background-color: grey; &:hover { background-color: white } } .tab { /**/ } .citation { /**/ } } /*下面复用上面的一部分代码*/ #header a { color: orange; #bundle > .button; }
编译生成:
#bundle .button { display: block; border: 1px solid black; background-color: grey; } #bundle .button:hover { background-color: white; } #bundle .tab { /**/ } #bundle .citation { /**/ } /*下面复用上面的一部分代码*/ #header a { color: orange; display: block; border: 1px solid black; background-color: grey; } #header a:hover { background-color: white; }
LESS中的命名空间,属于高级语法,在平常项目中应用比较普遍。咱们能够用LESS中的命名空间为本身封装一些平常比较经常使用的类名,以便之后作项目的时候更有效率。
子类里面的优先,找不到才往父类里找。
示例:
@var: red; #page { @var: white; #header { color: @var; // 这里值是white } }
也不会由于变量后面定义而影响做用域:
@var: red; #page { #header { color: @var; // white } @var: white; }
和上面的例子是同样的。
css仅支持块注释。less里块注释和行注释均可以使用:
/* 一个注释块 style comment! */ @var: red; // 这一行被注释掉了! @var: white;
和css同样,你能够导入一个 .less
文件,此文件中的全部变量就能够所有使用了。若是导入的文件是 .less
扩展名,则能够将扩展名省略掉:
@import "library"; // library.less @import "typo.css";
这些日常应该用的很少吧。
color(string) 解析颜色,将表明颜色的字符串转换为颜色值 convert(value,unit) 将数字从一种单位转换到另外一种单位.第一个参数为带单位的数值,第二个参数为单位. ceil(number)向上取整 floor(number)向下取整 percentage(number)将浮点数转换为百分比字符串 round(number)四舍五入取整 sqrt(number)计算一个数的平方根,并原样保持单位 pow(number,number)设第一个参数为A,第二个参数为B,返回A的B次方. mod(number,number)返回第一个参数对第二参数取余的结果. min(value1, ..., valueN)返回一系列值中最小的那个. max(value1, ..., valueN)返回一系列值中最大的那个. abs(number)计算数字的绝对值,并原样保持单位 sin(number)正弦函数 cos(number)余弦函数 asin(number)反正弦函数.返回以弧度为单位的角度,区间在 -PI/2 到 PI/2之间. acos(number)反余弦函数.区间在 0 到 PI之间. tan(number)正切函数 atan(number)反正切函数 pi()返回圆周率 π (pi) isnumber(value)若是待验证的值为数字则返回 true,不然返回 false isstring(value)若是待验证的值是字符串则返回 true,不然返回 false iscolor(value)若是待验证的值为颜色则返回 true,不然返回 false
更多:http://less.bootcss.com/functions/
第三方的编译工具备不少,下面列举经常使用的。
官网:http://lesscss.org
github:http://github.com/less/less.js
须要先安装node.js。
安装好nodejs后,在命令行输入:
npm install -g less
以安装lessc。
安装 Less 后,就能够在命令行上调用 Less 编译器了,以下:
lessc styles.less
这将输出编译以后的 CSS 代码到stdout
,你能够将输出重定向到一个文件:
lessc styles.less > styles.css
若要输出压缩过的 CSS,只需添加 -x 选项:
lessc styles.less > styles.css -x
若是但愿得到更好的压缩效果,还能够经过 --clean-css
选项启用 Clean CSS
进行压缩,须要先安装好插件:
npm install -g less-plugin-clean-css
执行 lessc
且不带任何参数,就会在命令行上输出全部可用选项的列表。
lessc
暂不支持实时编译。
官网:http://koala-app.com/index-zh.html
下载:https://pan.baidu.com/s/1o7wLvPg
使用Koala是由于它是个客户端,更简单。更重要的,还能实时编译,这对于实际开发颇有帮助。
koala是一个前端预处理器语言图形编译工具,支持Less、Sass、Compass、CoffeeScript,帮助web开发者更高效地使用它们进行开发。跨平台运行,完美兼容windows、linux、mac。
使用起来很简单,只须要将less文件所在的目录拖到软件工做窗口,选择须要编译的less文件就好了。只要你改动less文件里的代码,就会自动生成同名的css文件。速度很是快。感兴趣的能够下载试试。
Less-sublime:less语法高亮
lessc:Less 即时保存编译 CSS 插件
官网:http://www.dcloud.io/
一款国人开发的很不错的代码编辑器,基于eclipse,前端的同窗建议下载。
号称:飞速编码的极客工具,手指爽,眼睛爽。支持php、jsp、ruby、python、nodejs等web语言,less、coffee等编译型语言。代码提示功能真的很强大。
该软件默认安装了less4j,支持实时将less文件编译成同名的css文件。对less的代码提示是我见过最强大的,变量什么的都会提示。
仅支持语法高亮。
Less.js 语法高亮,by azrafe7
Less.js 语法高亮, by Raúl Salitrero
一样须要先安装node.js。
而后安装:
npm install --save-dev gulp
接着安装less插件:
npm install gulp-less --save-dev
开始任务配置:
gulpfile.js
var gulp = require('gulp'); var less = require('gulp-less'); gulp.task('doless', function () { return gulp.src('css/*.less') .pipe(less()) .pipe(gulp.dest('build')); }); gulp.task('watch', function () { gulp.watch('css/*.less', ['doless']); });
在命令行执行:
gulp watch
咱们如今去编辑css/demo.less
文件,会自动在build目录生成demo.css
文件。
更多less编译工具查看:http://less.bootcss.com/usage/#guis-for-less