众所周知,less是一门css预处理语言,其他的类似还有scss、Stylus 等,和js相似度比较高的就是less了。话不多说,我们来看less的使用。

Node.js 环境中使用 Less :

npm install -g less

> lessc styles.less styles.css

我用的vscode,编译后css文件在vscode项目文件里显示不出来,但是在本地路径下查看得到。

在浏览器环境中使用 Less :

<link rel="stylesheet/less" type="text/css" href="styles.less" />
<script src="//cdnjs.cloudflare.com/ajax/libs/less.js/3.8.1/less.min.js" ></script>

1.变量的使用

Less中,变量由变量名称和值组成。变量名以 @ 为前缀,由字母、数字、_和-组成,变量名称和值之间用冒号隔开

@width:80%;
@height:100px;
@color:blue; .box{
width:@width;
height:@height;
background-color: @color;
margin-top: 5px;
}
.box1{
width:@width+10px;
height:@height;
background-color: @color;
margin-top: 10px;
}
.box2{
width:@width+20px;
height:@height;
background-color: @color;
margin-top: 5px;
}

less变量也分全局变量和局部变量,不仅可以直接在属性值中使用变量,还可以用类似 @{name} 的结构,以“插值”的方式在选择器名、属性名、URL、import、媒体查询中使用变量。在编译时,变量将被替换为它们相应的值。

2.混合(是一种将一组属性从一个规则集包含到另一个规则集的方法)

.box1{
width:@width+20px;
height:@height;
background-color: @color;
margin-top: 5px;
.bordered();
}
.bordered{
border-top:dotted 1px #ff0000;
border-bottom:solid 2px #;
}

恩,就是定义一个类似函数的东西,然后引用它就行

3.嵌套

@width:%;
@height:100px;
@color:pink; .box{
width:@width;
height:@height;
background-color: @color;
margin-top: 5px;
p{
color:red;
font-size: 12px;
}
.username{
color:#eeeeee;
font-size: 16px
}
}

等效于

.box{width:@width;height:@height;background-color:@color;margin-top: 5px; }
.box p{color:red;font-size: 12px;}
.box .username{color:red;font-size: 12px;}

这波操作也是很骚了,是不是想到了js函数嵌套啊~

4.运算

官网翻译哈:算术运算+、-、*、/可以对任何数字、颜色或变量进行运算。如果可能的话,数学运算在加、减或比较之前会考虑到单位并转换数字。结果具有最左边的显式单位类型。如果转换不可能或没有意义,则忽略单位。不可能的转换示例:px到cm或rad到%。

@count-:5cm+10mm;
@count-:5cm+10mm-2mm;
@count-:5cm+10px;
@count-:5cm-10px;
@count-:5cm-10mm+50px;
@base:%;
@filter:@base*;
@color:#;
.d1{
width:@count-;
background-color: @color+#;
}
.d2{
width:@count-;
background-color: @color+#;
}
.d3{
width:@count-;
background-color: @color+#;
}
.d4{
width:@count-;
background-color: @color+#;
}
.d5{
width:@count-;
background-color:@color+#fff;
}

效果图

5.Escaping

转义允许您使用任意字符串作为属性或变量值。在~“anything”或~“anything”中的任何内容都将按原样使用,除了插值之外没有任何更改。

@min768: ~"(min-width: 768px)";
.element {
@media @min768 {
font-size: .2rem;
}
} 等效于 @media (min-width: 768px) {
.element {
font-size: .2rem;
}
}

感觉是给了你自由,反而让人有点不习惯来了呢~

6.函数

这是我们最经常用到的东西,但是用法也很多,具体的还是参见函数手册

@width:0.5;
@base:#c0b40c;
.class{
width:percentage(@width);
color:saturate(@base,%);
background-color: spin(lighten(@base, %), );
}

丑图

7.命名空间和访问器

#bundle() {
.button {
display: block;
border: 1px solid black;
background-color: grey;
}
.font{...}
.tab{...}
} #header a {
color: orange;
#bundle.button(); // 也可以写成#bundle > .button
}

这也是为了方便函数复用了,命名空间选择器了解一下。

命名空间不加()也行。

.box{
width:@width;
height:@height;
background-color: @color;
.username{
color:#eeeeee;
font-size: 16px;
}
}
.box1{
.box.username;
width:@width;
height:@height;
background-color: @color; }

8.Map

从3.5以下的版本开始,可以使用mixin和ruleset作为值的映射

#library() {
.colors() {
primary: green;
secondary: blue;
}
} #library() {
.colors() { primary: grey; }
} .button {
color: #library.colors[primary];
border-color: #library.colors[secondary];
} //等效于
//.button { color: grey; border-color: blue; }  

再次感叹万能的对象!

这些还只是初步的less语法知识,下次我们再来深入了解吧!推荐大家去less官网学习,官网上够详细啦

 

随机推荐

  1. phpstudy等php本地环境运行缓慢的问题解决方法

    我们经常会使用些一键安装包部署本地服务器环境.比如phpstudy.但是会有不少人发现,wordpress等使用数据库的程序打开或者切换页面的速度明显低于静态站点.甚至需要好几秒.这个问题一直困扰了我 ...

  2. Flexbox弹性布局

    Flexbox,一种CSS3的布局模式,也叫做弹性盒子模型,用来为盒装模型提供最大的灵活性.最新版本兼容IE11+.firefox.safari.chrome.opera及移动端,但移动端ios7.1 ...

  3. java线程介绍

    文章讲解要点 1.线程创建几种方式2.线程常见设置方法,包括优先级.优先级休眠.停止等3.多线程间的数据交互与锁机制4.项目源码下载   线程介绍.png 一.线程创建方式 常见的线程创建方法以下三种 ...

  4. 前后端交互实现(nginx,json,以及datatable的问题相关)

    1.同源问题解决 首先,在同一个域下搭建网络域名访问,需要nginx软件,下载之后修改部分配置 然后再终端下cmd  nginx.exe命令,或者打开nginx.exe文件,会运行nginx一闪而过, ...

  5. [Web][高中同学毕业分布去向网站+服务器上挂载]二、敲定思路与方向(HTML5+JS(JQuery+ECharts))

    高中同学毕业分布网站:敲定思路 一.背景 第一集:http://www.cnblogs.com/Twobox/p/8368121.html 中大体确定了自己的 大体目标.大体思路. 但是 . 在今天的 ...

  6. sql左外连接和右外连接的区别例子转摘

    sql左外连接和右外连接的区别   两个表:A(id,name)数据:(1,张三)(2,李四)(3,王五)B(id,name)数据:(1,学生)(2,老师)(4,校长) 左连接结果:select A. ...

  7. 注册Github过程

    第一步当然是建立自己的账号密码了: 一: github官网地址:https://github.com/ (1)第一步:首先起一个属于自己用户的名字(username),用户名字只能包含字母数字的字符或 ...

  8. wc基础功能

    第一次作业 项目地址 https://gitee.com/xxlznb/WordCount PSP WordCount 预估耗时(分钟) 实际耗时 计划 20 30 预估任务需要时间 20 30 开发 ...

  9. Python XML解析之ElementTree

    参考网址: http://www.runoob.com/python/python-xml.html https://docs.python.org/2/library/xml.etree.eleme ...

  10. Python列表之班荆道故

    列表list初识 列表是python的基础数据类型之一 ,它是以[ ]括起来, 每个元素用' , '隔开而且可以存放各种数据类型: list列表的定义: list_ = []list_1 = [&qu ...