less的基本使用
众所周知,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官网学习,官网上够详细啦
随机推荐
- 环境搭建 - Java(Windows)
Java开发环境搭建 本文以window7下搭建JDK8示例,其他版本无特殊说明同理. 下载JDK安装包 网址:JDK8 非C盘下根目录新建文件夹:Java D:\Java 安装JDK至Jav ...
- SAP MM 事务代码MI31之思考
SAP MM 事务代码MI31之思考 1 - MI01之痛 多年SAP项目实施实践中,笔者之前对于SAP系统里盘点凭证创建(MI01)事务代码里的输入界面很是不爽: 第一,MI01输入了一行数据以后, ...
- 虚拟主机、VPS主机与云服务器的区别
本文转载自星光云 http://www.365yun.top/news/list.asp?newsid=22 虚拟主机是利用虚拟技术将一台物理服务器划分成多个“虚拟”服务器,虚拟主机的出现大大节省了服 ...
- ASP.NET Core 一步步搭建个人网站(1)_环境搭建
ASP.NET Core2.0发布有一阵子了,这是.NET 开源跨平台的一个重大里程碑, 也意味着比1.0版本要更加成熟.目前.net core具有开源.跨平台.灵活部署.模块化架构等等特性,吸引着一 ...
- Xamarin 学习笔记 - 配置环境(Windows & iOS)
本文翻译自CodeProject文章:https://www.codeproject.com/Articles/1223980/Xamarin-Notes-Set-up-the-environment ...
- react基础语法二
这里只是对自己的学习进行一次总结,也是为了让自己以后如果长时间不使用快速记忆起来的笔记,如果想要学习,还是去官网看文档比较好一些.. 注意 下面的代码的 script标签的type类型都为 “text ...
- 使用 Browser-solidity 在 Go-Ethereum1.7.2 上进行简单的智能合约部署
目录 目录 1.基本概念 1.1.什么是智能合约? 1.2.什么是Solidity? 1.2.1.Solidity的语言特性 1.3.什么是 Browser-solidity? 2.Browser-s ...
- Class.isAssignableFrom与instanceof的区别
isAssignableFrom 假设有两个类Class1和Class2.Class1.isAssignableFrom(Class2)表示: 类Class1和Class2是否相同. Class1是否 ...
- Swift JSON字符串和字典以及数组的互转
1.JSONString转换为字典 // JSONString转换为字典 func getDictionaryFromJSONString(jsonString:String) ->NSDict ...
- 消息 4900,级别 16,状态 2,第 1 行 对表 'XX.XXX' 执行 ALTER TABLE SWITCH 语句失败。对于已启用更改跟踪的表,不可能切换其分区。请先禁用更改跟踪,再使用 ALTER TABLE SWITCH。
问题描述: 今天处理切换分区数据的时候出现了这个错误: 消息 4900,级别 16,状态 2,第 1 行 对表 'XX.XXX' 执行 ALTER TABLE SWITCH 语句失败.对于已启用更改跟 ...