vue2 less less-loader 的用法
LESS基础语法
我们一起来学习一下LESS的基础语法,LESS的基础语法基本上分为以下几个方面:变量、混合(Mixins)、嵌套规则、运算、函数、作用域等。这些基础语法需要我们先牢牢的掌握住,然后才可以灵活的在项目中进行实战。
变量
和JS中的变量一样,只是LESS的变量定义不是使用VAR而是使用@。
//->LESS代码
@link-color: #428bca;
@link-color-hover: darken(@link-color, 10%); a {
color: @link-color;
&:hover {
color: @link-color-hover;
}
} .box {
color: @link-color;
} //->编译为CSS的结果
a {
color: #428bca;
} a:hover {
color: #3071a9;
} .box {
color: #428bca;
}
除了上述用变量存储公用的属性值,我们还可以用变量存储公用的URL、选择器等等
//->LESS代码
.@{selector} {
width: 100px;
height: 100px;
@{property}: #000;
background: url("@{bgImg}/test.png"); &:after {
display: block;
content: @@var;
}
}
@selector: box;
@bgImg: "../img";
@property: color;
@name: "less基础";
@var: "name"; //->编译为CSS的结果
.box {
width: 100px;
height: 100px;
color: #000;
background: url("../img/test.png");
} .box:after {
display: block;
content: "百度";
}
在上述的代码中我们发现,变量存储的值可以作为选择器,也可以作为样式属性名,同样也可以像类似于JS中字符串拼接的方式把变量值的和另外一个字符串进行拼接,而且@@var是把var变量存储的值作为另外一个变量的名从而获取对应的值。还有一点值的我们注意的是,变量可以定在使用代码的下面,这个有点类似于JS中的预解释,不管写在上面还是下面,都是相当于全局的变量,并且都可以把存储值获取到(但是建议大家把变量都统一在最上面定义)。
Mixin混合
1、基本使用
从字面意思上理解,所谓的混合其实应该是把很多的样式混合在一起,这样理解不准确,个人的理解,所谓的混合其实是把某个选择器中的样式拿过来使用,我们看下面的代码。
//->LESS代码
.public {
width: 100px;
height: 100px;
} nav ul {
.public;
list-style: none;
} //->编译为CSS的结果
.public {
width: 100px;
height: 100px;
} nav ul {
width: 100px;
height: 100px;
list-style: none;
}
观察上述的代码,我们发现其实nav ul是把public中设定的样式属性值copy了一份到自己的样式中。如果你想在编译完成的结果中不输出public这个样式的结果,只需要按照下述的代码编写即可:
//->LESS代码
.public() {//->在选择器后面加上()就可以不编译这个样式了
width: 100px;
height: 100px;
} nav ul {
.public;
list-style: none;
} //->编译为CSS的结果
nav ul {
width: 100px;
height: 100px;
list-style: none;
}
2、Extend
虽然在上述的案例中,nav ul把public中的样式继承了过来,但是原理却是把代码copy一份过来,这样编译后的CSS中依然会存留大量的冗余CSS代码,为了避免这一点,我们可以使用extend伪类来实现样式的继承使用。
//->LESS代码
.public {
width: 100px;
height: 100px;
} nav ul {
&:extend(.public);
list-style: none;
} //->编译为CSS的结果
.public, nav ul {
width: 100px;
height: 100px;
} nav ul {
list-style: none;
}
或者:
//->LESS代码
.public {
width: 100px;
height: 100px;
} nav ul:extend(.public) {
list-style: none;
} //->编译为CSS的结果和第一种写法一样
3、命名空间和作用域
在LESS的语法中,我们可以指定命名空间,实现在一个盒子中层级嵌套式的编写。下面案例中,.box就是命名空间,里面的img、.gray都是这个空间下的样式,调取的话需要.box > .gray。
//->LESS代码
.box {
width: 100px;
height: 100px;
img {
width: 100%;
height: 100%;
}
.gray {
color: #eee;
}
&:hover {
background: green;
}
} #nav {
.box;
} #header {
.box > .gray;
} //->编译为CSS的结果
.box {
width: 100px;
height: 100px;
} .box img {
width: 100%;
height: 100%;
} .box .gray {
color: #eee;
} .box:hover {
background: green;
} #nav {
width: 100px;
height: 100px;
} #nav img {
width: 100%;
height: 100%;
} #nav .gray {
color: #eee;
} #nav:hover {
background: green;
} #header {
color: #eee;
}
在LESS中定义了命名空间就创建了一个私有的作用域,在这个私有作用域中使用的变量都是先看一下自己作用域中有没有,没有的话,在向上一级查找(类似于JS的作用域链)。
//->LESS代码
@color: #ccc;
.box {
@color: #eee;
.gray {
color: @color;
}
} .box2 {
.gray {
color: @color;
}
} //->编译为CSS的结果
.box .gray {
color: #eee;
} .box2 .gray {
color: #ccc;
}
4、!important
在调用的混合集后面追加 !important 关键字,可以使混合集里面的所有属性都继承 !important:
//->LESS代码
@color: #ccc;
.box {
@color: #eee;
.gray {
color: @color;
}
} nav ul {
.box !important;
} //->编译为CSS的结果
.box .gray {
color: #eee;
} nav ul .gray {
color: #eee !important;
}
5、Parametric Mixins
如同JS一样,LESS也可以向函数一样设定形参数,这个技巧在我们的项目中会被经常的使用到,例如:处理CSS3的兼容问题
//->LESS代码
.transition(@property:all;@duration:1s;@function:linear;@delay:0s;) {
-webkit-transition: @property @duration @function @delay;
-moz-transition: @property @duration @function @delay;
-ms-transition: @property @duration @function @delay;
-o-transition: @property @duration @function @delay;
transition: @property @duration @function @delay;
} .box1 {
.transition;
} .box2 {
.transition(@duration: 2s);
} .box3 {
.transition(@duration: 2s; @property: width;);
} //->编译为CSS的结果
.box1 {
-webkit-transition: all 1s linear 0s;
-moz-transition: all 1s linear 0s;
-ms-transition: all 1s linear 0s;
-o-transition: all 1s linear 0s;
transition: all 1s linear 0s;
} .box2 {
-webkit-transition: all 2s linear 0s;
-moz-transition: all 2s linear 0s;
-ms-transition: all 2s linear 0s;
-o-transition: all 2s linear 0s;
transition: all 2s linear 0s;
} .box3 {
-webkit-transition: width 2s linear 0s;
-moz-transition: width 2s linear 0s;
-ms-transition: width 2s linear 0s;
-o-transition: width 2s linear 0s;
transition: width 2s linear 0s;
}
此外我们需要值得注意的是,LESS中也有arguments。
//->LESS代码
.transition(@property:all;@duration:1s;@function:linear;@delay:0s;) {
-webkit-transition: @arguments;
transition: @arguments;
} .box1 {
.transition;
} //->编译为CSS的结果
.box1 {
-webkit-transition: all 1s linear 0s;
transition: all 1s linear 0s;
}
我们还可以把我们的变量像JS的函数一样操作,不仅仅有参数,还有返回值。
//->LESS代码
.average(@x, @y) {
@result: ((@x + @y) / 2);
} div {
.average(16px, 50px); //"call" the mixin
padding: @result; //use its "return" value
} //->编译为CSS的结果
div {
padding: 33px;
}
6、Mixin Guards
我们可以在mixin中设置条件;常用的条件运算符:>、>=、<、<=、=;我们设定的条件还可以使用IS函数:iscolor、isnumber、isstring、iskeyword、isurl、ispixel、ispercentage...
//->LESS代码
.mixin (@a) when (lightness(@a) >= 50%) {
background-color: black;
} .mixin (@a) when (lightness(@a) < 50%) {
background-color: white;
} .box1{
.mixin(#ddd);
} .box2{
.mixin(#555);
} //->编译为CSS的结果
.box1 {
background-color: black;
} .box2 {
background-color: white;
}
when是在设置条件,除了像上面的写法外,我们还可以通过when设置多个条件,而且条件中可以使用is函数。
//->LESS代码:使用IS函数
.mixin (@a; @b: 0) when (isnumber(@b)) { ... }
.mixin (@a; @b: black) when (iscolor(@b)) { ... } //->LESS代码:多条件,可以使用and或者逗号间隔
.mixin (@a) when (isnumber(@a)) and (@a > 0) { ... }
.mixin (@a) when (isnumber(@a)) , (@a > 0) { ... }
我们还可以通过与&特性结合实现'if'类型的语句。
//->LESS代码:这里的意思是如果为true,.box的文字颜色才是白色
@my-option: true;
& when (@my-option = true) {
.box {
color: white;
}
}
Loops
在Less中,混合可以调用它自身。这样,当一个混合递归调用自己,再结合Guard条件表达式,就可以写出循环结构。使用递归循环最常见的情况就是生成栅格系统的CSS:
//->LESS代码
.generate-columns(4);
.generate-columns(@n, @i: 1) when (@i <= @n) {
.column-@{i} {
width: (@i * 100% / @n);
}
.generate-columns(@n, (@i + 1));
} //->输出的CSS
.column-1 {
width: 25%;
} .column-2 {
width: 50%;
} .column-3 {
width: 75%;
} .column-4 {
width: 100%;
}
Merge
Merge特性可以从多个属性中将值,集合到某一个样式属性的列表中(也就是多样式效果)。在编写的时候,+代表以逗号分隔,+_代表多个之前以空格分隔。
//->LESS代码
.mixin() {
box-shadow+: inset 0 0 10px #555;
} .myclass {
.mixin;
box-shadow+: 0 0 20px black;
} .mixin2() {
transform+_: scale(2);
} .myclass2 {
.mixin2;
transform+_: rotate(45deg);
} //->输出的CSS
.myclass {
box-shadow: inset 0 0 10px #555, 0 0 20px black;
} .myclass2 {
transform: scale(2) rotate(45deg);
}
Parent Selectors
&运算符其实就是让当前的选择器和父级选择器按照特定的规则进行连接,看下面的案例:
//->LESS代码
.box {
color: blue;
&:hover {
color: green;
} &-top {
height: 30px;
} &-center {
height: 500px;
} //->多个&&
& + &-top {
color: red;
} & &-top {
color: grey;
} &&-top {
color: black;
} &, &-top {
color: orange;
}
} //->输出的CSS
.box {
color: blue;
} .box:hover {
color: green;
} .box-top {
height: 30px;
} .box-center {
height: 500px;
} .box + .box-top {
color: red;
} .box .box-top {
color: grey;
} .box.box-top {
color: black;
} .box, .box-top {
color: orange;
}
改变选择器顺序,下面的案例中,选择器.no-border-radius &会前置插入它的父选择器.header .menu,最后变成.no-border-radius .header .menu形式输出:
//->LESS代码
.header {
.menu {
border-radius: 5px;
.no-border-radius & {
background-image: url('images/button-background.png');
}
}
} //->输出的CSS
.header .menu {
border-radius: 5px;
} .no-border-radius .header .menu {
background-image: url('images/button-background.png');
}
Import Directives
从其他样式表中导入样式。
//->LESS代码
@import "public.less"; .box {
&:after {
.clear;
}
} //->输出的CSS:会把public中的样式也输出
.clear {
display: block;
height: 0;
content: "";
clear: both;
zoom: 1;
} .box:after {
display: block;
height: 0;
content: "";
clear: both;
zoom: 1;
}
我们发现上述的操作虽然实现了调取使用,但是会把public中的less也编译到了自己的这个css中,如果不想编译的话,我们需要配置一些参数:
//->LESS代码
@import (reference) "public.less"; .box {
&:after {
.clear;
}
} //->输出的CSS:
.box:after {
display: block;
height: 0;
content: "";
clear: both;
zoom: 1;
}
除了reference以外我们还可以配置一些其他的参数值: inline:在输出中包含源文件但不加工它 less:将文件作为Less文件对象,无论是什么文件扩展名 css:将文件作为CSS文件对象,无论是什么文件扩展名 once:只包含文件一次(默认行为) multiple:包含文件多次
vue2 less less-loader 的用法的更多相关文章
- SQL LOADER 的用法 TXT文件导入非常之快
前提,需要本地安装ORACLE 客户端 控制文件 cms.ctl load dataCHARACTERSET UTF8infile 'oracle.txt'APPEND INTO TABLE JR f ...
- easyui-datagrid 的loader属性用法
API介绍比较简略: 定义如何从远程服务器加载数据.返回false可以放弃本次请求动作.该函数接受以下参数:param:参数对象传递给远程服务器.success(data):当检索数据成功的时候会调用 ...
- vue2.0 Axios 的简单用法
安装 使用 npm: $ npm install axios 使用 bower: $ bower install axios 使用 cdn: <script src="https:// ...
- vue2.0修饰符sync用法
如果子组件是一个弹窗,我们想通过点击关闭按钮来关闭子组件弹窗,子组件弹窗的v-show由变量isVisible控制,这个变量通过props由父组件来注入, 而子组件无法改变props里面的变量的值,但 ...
- oracle sqlloader 用法
向oracle中导入*.csv文件 1.什么是*.csv,如何得到? 里面存放的是数据表.每行代表数据库表格的一行, 每行中,每两个数据中间由逗号","分割. *.csv可以通 ...
- Android的CursorLoader用法小结
工作内容集中到Contact模块,这个应用查询数据的地方很多,其使用了CursorLoader这个工具大大简化了代码复杂度.Android自3.0提供了Loader机制,当时google的API只是简 ...
- [js高手之路]深入浅出webpack教程系列7-( babel-loader,css-loader,style-loader)的用法
什么是loader呢,官方解释为文件的预处理器,通俗点说webpack在处理静态资源的时候,需要加载各种loader,比如,html文件,要用html-loader, css文件要用css-loade ...
- sqlldr的用法 (这个最完整)
转自:http://blog.chinaunix.net/uid-23622436-id-2394093.html 一:在 Oracle 数据库中,我们通常在不同数据库的表间记录进行复制或迁移时会用以 ...
- SQL*Loader 详解
在 Oracle 数据库中,我们通常在不同数据库的表间记录进行复制或迁移时会用以下几种方法: 1. A 表的记录导出为一条条分号隔开的 insert 语句,然后执行插入到 B 表中2. 建立数据库间的 ...
- sqlldr 用法
转自:http://blog.chinaunix.net/uid-23622436-id-2394093.html 在 Oracle 数据库中,我们通常在不同数据库的表间记录进行复制或迁移时会用以下几 ...
随机推荐
- ccna学习指南第七版
1.加电post自检 闪存查找ios 可随时从命令行进入设置模式,为此可在特权模式下输入setup ctrl+c退出特权模式 6.2cli 命令行界面 进入cli router> ...
- tzcacm去年训练的好题的AC代码及题解
A - Tree UVA - 548 You are to determine the value of the leaf node in a given binary tree that is th ...
- 深度理解STL之map、set
课程设计做了这个一直没有整理(搬运 set算是关键字和相同的特殊map set应该更加被强调理解为“集合”,而集合所涉及的操作并.交.差等,即STL提供的如交集set_intersection().并 ...
- The 2018 ACM-ICPC Asia Qingdao Regional Contest, Online
A Live Love DreamGrid is playing the music game Live Love. He has just finished a song consisting of ...
- CCF认证题 搜索题
栋栋最近开了一家餐饮连锁店,提供外卖服务.随着连锁店越来越多,怎么合理的给客户送餐成为了一个急需解决的问题. 栋栋的连锁店所在的区域可以看成是一个n×n的方格图(如下图所示),方格的格点上的位置上可能 ...
- iOS UICollectionView高级用法(长按自由移动cell)
iOS 9之后: 示例如下 效果 前言: 看完你可以学到哪些呢? 就是文章标题那么多, 只有那么多. . 手残效果图没弄好. @property (nonatomic, strong) UIColle ...
- 【Luogu】P2473奖励关(期望DP)
题目链接 逆推期望DP.设f[i][j]为1~i-1中吃到的宝物集合为j,在i~k轮能得到的最大期望分数. 如果不吃显然f[i][j]+=f[i+1][j]/n 如果吃就是f[i][j]+=max(f ...
- HDU-3718 Similarity
题目只有26个字母,所以我们新建一个二分图,v[i][j]表示字母i对应字母j时能成功匹配的个数,给这个边矩阵v求个最大匹配就是答案. #include <cstdlib> #includ ...
- 浅谈android反调试之 API判断
反调试:利用Java层API来判断Android程序是否是处于被调试下. 1.直接调用系统的android.os.Debug.isDebuggerConnected()方法 我们进行动态调试的时候,其 ...
- [USACO13JAN] Cow Lineup (单调队列,尺取法)
题目链接 Solution 尺取法板子,算是复习一波. 题中说最多删除 \(k\) 种,那么其实就是找一个颜色种类最多为 \(k+1\) 的区间; 统计一下其中最多的颜色出现次数. 然后直接尺取法,然 ...