在 LESS 中我们可以定义一些通用的属性集为一个 class,然后在另一个 class 中去调用这些属性,下面有这样一个 class:

1

2

3

4

.bordered {

border-top: dotted 1px black;

border-bottom: solid 2px black;

}

那如果我们现在需要在其他 class 中引入那些通用的属性集,那么我们只需要在任何 class 中像下面这样调用就可以了:

1

2

3

4

5

6

7

8

9

.border_radius {

border-radius: 10px;

-moz-border-radius: 10px;

-webkit-border-radius: 10px;

}

#progress{

display: block;

.border_radius

}

任何 CSS class, id 属性集都可以以同样的方式引入。

注意:变量也会被混合,也就是说变量会被带到当前的作用域。这个特性还有争议,也许在未来会有变化。

对于常常操纵css3的我们,真事我们的救星,我们知道,如果一个网站中全部的圆角都用css3实现,那么用这种混合的方式真事帮我们省了不少事儿,可是灵活性上似乎差了点,例如圆角的尺寸等。别急,less还提供了其他的方法解决了这个问题。

~带参数混合

在 LESS 中,你还可以像函数一样定义一个带参数的属性集合:

1

2

3

4

5

.border_radius (@radius) {

border-radius: @radius;

-moz-border-radius: @radius;

-webkit-border-radius: @radius;

}

然后在其他 class 中像这样调用它:

1

2

3

4

5

6

#header {

.border_radius(4px);

}

.button {

.border_radius(6px);

}

这种方式是否解决了上边的那个问题;但是问题又出来了,这样的话我每回调用的时候都要写上参数,在圆角大部分都相同的情况下,调用时我都要写上同样的参数,似乎可以再简洁一点,而less的处理方式似乎也提供了这种方式,让我们更灵活的操纵代码,看如下代码:

我们还可以像这样给参数设置默认值:

1

2

3

4

5

.border_radius (@radius: 5px) {

border-radius: @radius;

-moz-border-radius: @radius;

-webkit-border-radius: @radius;

}

所以现在如果我们像这样调用它的话:

1

2

3

#header {

.border_radius;

}

radius 的值就会是 5px。

LESS混合方式也提供一种可以定义不带参数属性集合,如果你想隐藏这个属性集合,不让它暴露到 CSS 中去,但是你还想在其他的属性集合中引用,你会发现这个方法非常的好用:

1

2

3

4

5

6

7

8

9

.wrap(){

text-wrap: wrap;

white-space: pre-wrap;

white-space: -moz-pre-wrap;

word-wrap: break-word;

}

.pre {

.wrap;

}

编译过的CSS:

1

2

3

4

5

6

.pre {

text-wrap: wrap;

white-space: pre-wrap;

white-space: -moz-pre-wrap;

word-wrap: break-word;

}

以上为混合模式传一个参数,及不定义参数的详解,混合模式还提供了多参数混合模式,是我们操纵css的时候能灵活。

~多参数混合

多个参数可以使用分号或者逗号分隔,推荐使用分号分隔,因为逗号有两重含义:它既可以表示混合的参数,也可以表示一个参数中一组值的分隔符。

使用分号作为参数分隔符意味着可以将逗号分隔的一组值作为一个变量处理。换句话说,如果编译器在混合的定义或者是调用中找到至少一个分号,就会假设参数是使用分号分隔的,所有的逗号都属于参数中的一组值的分隔符。

2个参数,每个参数都含有通过逗号分隔的一组值的情况:.name(1, 2, 3; something, else)。

3个参数,每个参数只含一个数字的情况:.name(1, 2, 3)。

使用一个象征性的分号可以创建一个只含一个参数,但参数包含一组值的混合:.name(1, 2, 3;)。

逗号分隔的一组值参数的默认值:.name(@param1: red, blue;)。

使用同样的名字和同样数量的参数定义多个混合是合法的。在被调用时,LESS会应用到所有可以应用的混合上。比如你调用混合时只传了一个参数.mixin(green),那么所有只强制要求一个参数的混合都会被调用:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

.mixin(@color) {

color: @color;

}

.mixin(@color; @padding:2) {

color: @color;

padding: @padding;

}

.mixin(@color; @padding;30px; @margin: 2px) {

color: @color;

padding: @padding;

margin: @margin @margin @margin @margin;

}

.header-nav li a{

.mixin(#008000);

}

编译成的css:

1

2

3

4

.header-nav li a{

color: #008000;

padding: 2;

}

首先,看上个片段的代码你会发现,为什么第三个.mixin的margin没有解析出来?

其次padding为什么失效?

先说第一个问题,显然,在调用第三个.mixin方法的时候padding没有值,也没有传值,没传值的结果字面上显示的是此处第三个方法不被调用。

第二个问题,因为padding的值没有单位,所以被浏览器解析出来但是失效 。

针对第一个问题我们稍作修改验证一下,如果第一种真的是因为我说的那个缘故,那么我们给他穿个参数看能否被调用:

1

2

3

.header-nav li a{

.mixin(#008000;20p);

}

浏览器中被编译的css结果:

1

2

3

color: #008000;

padding: 20px;

margin: 2px 2px 2px 2px;

显然当第二位有参数的时候,第三个.mixin方法被调用了。

那如果第二个参数不传单位,看会被编译成什么结果:

1

2

3

.header-nav li a{

.mixin(#008000;20;);

}

被编译的css结果

1

2

3

color: #008000;

padding: 20;

margin: 2px 2px 2px 2px;

显然,以上的说法成立。

~@arguments 变量

@arguments在Mixins中是一个很特别的参数,当Mixins引用这个参数时,他将表示所有的变量,当你不想处理个别的参数时,这个将很有用,我们来看一个阴影的实例:

1

2

3

4

5

6

.box_shadow (@x: 0, @y: 0, @blur: 1px, @color: #000) {

box-shadow: @arguments;

-moz-box-shadow: @arguments;

-webkit-box-shadow: @arguments;

}

.box_shadow(2px, 5px);

编译的css结果:

1

2

3

box-shadow: 2px 5px 1px #000;

-moz-box-shadow: 2px 5px 1px #000;

-webkit-box-shadow: 2px 5px 1px #000;

~高级参数用法与 @rest 变量

很多时候,我们的参数并不固定,尤其在css3的开发中这种问题尤为明显;混合模式中也为我们提供了在 mixin 中不限制参数的数量的方式,可以在变量名后添加 ...,表示这里可以使用 N 个参数。

1

2

3

4

5

.mixin (...) {        // 接受 0-N 个参数

.mixin () {           // 不接受任何参数

.mixin (@a: 1) {      // 接受 0-1 个参数

.mixin (@a: 1, ...) { // 接受 0-N 个参数

.mixin (@a, ...) {    // 接受 1-N 个参数

此外:

1

2

3

4

.mixin (@a, @rest...) {

// @rest 表示 @a 之后的参数

// @arguments 表示所有参数

}

怎么样。不错吧,这样开发起来是不是灵活性更高了呢!

开发时需注意的一点,有时候我们可能会使用hack !Important,调用时在混合后面加上!important关键字表示将混合带来的所有属性标记为!Important;

如:

1

2

3

4

5

6

7

8

9

10

.mixin (@a: 0) {

border: @a;

boxer: @a;

}

.unimportant {

.mixin(1);

}

.important {

.mixin(2) !important;

}

编译后:

1

2

3

4

5

6

7

8

.unimportant {

border: 1;

boxer: 1;

}

.important {

border: 2 !important;

boxer: 2 !important;

}

~混合模式还有两块内容,模式匹配与Guard表达式这里先暂不作介绍了。

下期为大家介绍LESS另一个特性,嵌套规则。

less语言特性(二) —— 混合的更多相关文章

  1. less语言特性(一) —— 变量

    近两年移动市场不断扩大,HTML5也逐渐升温,为了使我们前端工作更有效率,各种框架层出不穷,本章将介绍LESSCSS框架.LESSCSS是一种动态样式语言,属于CSS预处理语言的一种,它使用类似CSS ...

  2. JS 4 新特性:混合属性(mixins)

    Ext JS4的新特征1:混合属性(mixins) 组合是Extjs4的新特性,可用于实现多继承的情况.该属性会以同步方式加载类文件,并实例化该类(译者推理其内部使用Ext.create方法).直接上 ...

  3. C++ 语言特性的性能分析

    转载:http://www.cnblogs.com/rollenholt/archive/2012/05/07/2487244.html      大多数开发人员通常都有这个观点,即汇编语言和 C 语 ...

  4. Java 语言特性

    介绍以下几种语言特性: Java5的特性 1.静态引用 2.可变参数 3.自动装箱和拆箱  包装类的缓存设计 4.枚举 一.静态引用(语法糖,不推荐使用,了解一下即可) 先看看普通的引用,就是impo ...

  5. 与LINQ有关的语言特性

    在说LINQ之前必须先说说几个重要的C#语言特性 一:与LINQ有关的语言特性 1.隐式类型 (1)源起 在隐式类型出现之前, 我们在声明一个变量的时候, 总是要为一个变量指定他的类型 甚至在fore ...

  6. 第 4 章—— C# 语言特性(《精通 ASP.NET MVC 5》)

    这里只提供各个特性的简单概括. C# 的完整指南可参阅<Introducing Visual C#>.深度了解 LINQ 可参考<Pro LINQ in C#> 4.1 准备示 ...

  7. python程序设计——基本语言特性

    参考<Python程序设计(第2版)> 清华大学出版社 董付国 ##### 除特殊说明外,以下代码示例,均为python 3.6版本 ##### 一.Python语言特性 1.python ...

  8. LINQ体验(2)——C# 3.0新语言特性和改进(上篇)

    整体来说.Visual Studio 2008和.NET 3.5是建立在.NET2.0核心的基础之上,.NET2.0核心本身将不再变化(假设不了解.NET2.0的朋友,请參看MSDN或者一些经典的书籍 ...

  9. 偷窥篇:重要的C#语言特性——30分钟LINQ教程

    本文转自:http://www.cnblogs.com/liulun/archive/2013/02/26/2909985.html 千万别被这个页面的滚动条吓到!!! 我相信你一定能在30分钟之内看 ...

  10. scala 语言特性

    Scala 语言特性 Unit 表示无值, 等价于java, C++中的void Null 表示空值或空引用 Nothing 所有其他类型的子类型, 表示没有值 Any 所有类型的超类, 任何实例都属 ...

随机推荐

  1. CDN的那些细枝末节

    起源: 原本打算系统看看关于axios的介绍,无意中就看见一句"Using cdn",于是百度一下,"cdn"是什么? 名词解释:CDN CDN的全称是Cont ...

  2. javaweb项目中表单生成的验证码以及校验

    首先先来看一下项目的结构吧,有两个servlet,一个是进行验证码的生成以及存储的,一个是进行校验的,还有一个jsp页面是用来实现form表单的书写和展示: 我们只需要看这三个就行了,其他的自动忽略: ...

  3. iOS 9: UIStackView入门

    本文转自http://www.cocoachina.com/ios/20150623/12233.html 本文由CocoaChina译者candeladiao翻译,欢迎参加我们的翻译活动.原文:iO ...

  4. HTML-锚点-JS跳转锚点

    window.location.hash使用说明,这篇写的挺详细的 http://www.cnblogs.com/nifengs/p/5104763.html a标签的话是 name,div呢是id, ...

  5. 【Python3】端口占用监测的程序

    #!/usr/bin/env python # -*- coding:utf- -*- #python端口占用监测的程序,该程序可以监测指定IP的端口是否被占用 import socket,time, ...

  6. TCP端口号范围及分类

    https://blog.csdn.net/my_heart_/article/details/52601924 端口号的范围是从1-65535 端口的概念:  在网络技术中,端口(Port)大致有两 ...

  7. springboot---->springboot中的类型转换(一)

    这里面我们简单的学习一下springboot中关于类型转换器的使用.人世间的事情莫过于此,用一个瞬间来喜欢一样东西,然后用多年的时间来慢慢拷问自己为什么会喜欢这样东西. springboot中的类型转 ...

  8. 题目1005:Graduate Admission(录取算法)

    题目链接:http://ac.jobdu.com/problem.php?pid=1005 详解链接:https://github.com/zpfbuaa/JobduInCPlusPlus 参考代码: ...

  9. 题目1447:最短路(Floyd算法)

    题目链接:http://ac.jobdu.com/problem.php?pid=1447 详解链接:https://github.com/zpfbuaa/JobduInCPlusPlus 参考代码: ...

  10. [工具] Sublime Text 使用指南

    http://bbs.it-home.org/thread-46291-1-1.html 摘要(Abstract) 更新记录 更正打开控制台的快捷键为Ctrl + ` 更正全局替换的快捷键为Ctrl ...