您现在的位置是:网站首页> 编程资料编程资料
动态的样式语言less语法详解之混合属性LESS 让css也支持变量,运算符,include,嵌套规则等等 less让css具有动态语言的特性LESS 让css也支持变量,运算符,include,嵌套规则CSS less优化学习CSS预处理器:Sass和less进行对比Less里css表达式的写法示例介绍less开发指南CSS Less框架基础教程LESSCSS让CSS使用起来更加灵活成就CSS动态化
2021-09-06
879人已围观
简介 这篇文章主要介绍了动态的样式语言less语法详解之混合属性,需要的朋友可以参考下
前面介绍了less的变量和extend语法,今天在研究下混合属性(Mixin)。混合可以说是less的另一个特征,你可以将通用属性定义在一块,然后使用时直接调用此混合属性。
混合:
在 LESS 中我们可以定义一些通用的属性集为一个选择器,然后在另一个选择器中去调用这些属性. 例如:
.a, #b {
color: red;
}
.mixin-class {
.a();
}
.mixin-id {
#b();
}
编译后
.a, #b {
color: red;
}
.mixin-class {
color: red;
}
.mixin-id {
color: red;
}
注意:在调用混合时,可以加括号也可以不加括号。下面这个也是对的:
.a, #b {
color: red;
}
.mixin-class {
.a;
}
.mixin-id {
#b;
}
如果你只想定义一个混合,则可以再选择器后面加上括号,如下:
.my-mixin {
color: black;
}
.my-other-mixin() {
background: white;
}
.class {
.my-mixin;
.my-other-mixin;
}
编译后,加括号的.my-other-mixin()不会被编译。
.my-mixin {
color: black;
}
.class {
color: black;
background: white;
}
任何 CSS class, id 或者 元素 属性集都可以以同样的方式引入.通用选择器中可以嵌套选择器。
命名空间:
如果你想混合属性在一个更复杂的选择器,可以叠放多个id或类。如下:
#outer {
.inner {
color: red;
}
}
如果想使用这个混合属性,你可以这样,下面四个都是等价的
.c{
#outer > .inner;
}
.c{
#outer > .inner();
}
.c{
#outer.inner;
}
.c{
#outer.inner();
}
你可以将混合属性定义在一个id的下面,这样就避免了与其他混合冲突。
关键字!important:
在使用混合属性后面加上!important关键字,则混合中的所有属性都会加上关键字!important。例如:
.foo (@bg: #f5f5f5, @color: #900) {
background: @bg;
color: @color;
}
.unimportant {
.foo(1);
}
.important {
.foo(2) !important;
}
编译后
.unimportant {
background: #f5f5f5;
color: #900;
}
.important {
background: #f5f5f5 !important;
color: #900 !important;
}
带参数的混合:
混合属性也可以通过括号传递参数,如下:
.border-radius(@radius) {
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
border-radius: @radius;
}
我们只需要在使用它的时候传递一个参数即可,如下:
#header {
.border-radius(4px);
}
.button {
.border-radius(6px);
}
当然我们也可以给参数一个默认值,这样使用的时候可以传值也可以不传值。如下:
.border-radius(@radius: 5px) {
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
border-radius: @radius;
}
如果我们没有传值,则会使用默认值5px。
当然我们也可以传递多个参数,如下:
.mixin(@color) {
color-1: @color;
}
.mixin(@color; @padding:2) {
color-2: @color;
padding-2: @padding;
}
.mixin(@color; @padding; @margin: 2) {
color-3: @color;
padding-3: @padding;
margin: @margin @margin @margin @margin;
}
.some .selector div {
.mixin(#008000);
}
编译后
.some .selector div {
color-1: #008000;
color-2: #008000;
padding-2: 2;
}
从编译的结果可以看出,less也有函数重载的特性。当我们定义相同混合属性名,参数不同,然后.mixin(#008000);调用,第一和第二混合都能匹配,但是第三个缺少参数@padding的值,所以不会引用第三个混合属性。
我们不仅可以传多个值,还可以指定属性名传值,如下:
.mixin(@color: black; @margin: 10px; @padding: 20px) {
color: @color;
margin: @margin;
padding: @padding;
}
.class1 {
.mixin(@margin: 20px; @color: #33acfe);
}
.class2 {
.mixin(#efca44; @padding: 40px);
}
关键字@arguments:
@arguments有特殊的含义,类似于js的arguments,他包含了传递给混合属性的所有参数,如下:
.box-shadow(@x: 0; @y: 0; @blur: 1px; @color: #000) {
-webkit-box-shadow: @arguments;
-moz-box-shadow: @arguments;
box-shadow: @arguments;
}
.big-block {
.box-shadow(2px; 5px);
}
编译后
.big-block {
-webkit-box-shadow: 2px 5px 1px #000;
-moz-box-shadow: 2px 5px 1px #000;
box-shadow: 2px 5px 1px #000;
}
关键字@reset:
与@arguments不同的是@reset包含除指明参数之外的参数,例如:
.mixin(@a; @rest...) {
// @rest包含了@a之后的参数
// @arguments包含了所有参数
}
模式匹配:
有时候你想让混合根据你传入的参数做不同的事情,比如:
.mixin(dark; @color) {
color: darken(@color, 10%);
}
.mixin(light; @color) {
color: lighten(@color, 10%);
}
.mixin(@_; @color) {
display: block;
}
.class {
.mixin(@switch; #888);
}
对于.class你赋给变量@switch不同的值,不同的混合属性会被调用,比如
@switch: light;
编译后
.class {
color: #a2a2a2;
display: block;
}
作为函数使用Mixin:
当我们把混合当做函数使用时,在调用函数之后,函数中的变量是可以使用的,除非调用混合属性的元素自己定义了同样的变量。比如:
.mixin() {
@width: 100%;
@height: 200px;
}
.caller {
.mixin();
width: @width;
height: @height;
}
编译后
.caller {
width: 100%;
height: 200px;
}
使用表达式:
.average(@x, @y) {
@average: ((@x + @y) / 2);
}
div {
.average(16px, 50px); // "call" the mixin
padding: @average; // use its "return" value
}
编译后
div {
padding: 33px;
}
LESS VS SASS
同类框架还有 SASS : http://sass-lang.com/, 与 LESS 相比,两者都属于 CSS 预处理器,功能上大同小异,都是使用类似程序式语言的方式书写 CSS, 都具有变量、混入、嵌套、继承等特性,最终目的都是方便 CSS 的书写及维护。
相关内容
- CSS3属性background-size使用指南CSS3 background-image颜色渐变的实现代码CSS3混合模式mix-blend-mode/background-blend-mode简介css3实现一个div设置多张背景图片及background-image属性实例演示CSS的background属性及CSS3的背景图片设置总结使用CSS3来实现滚动视差效果的教程css3中背景尺寸background-size详解详解background属性的8个属性值(面试题)
- 分享一个2014年圣诞节倒计时页面特效纯js实现圣诞节在线动态倒计时效果源码2014年圣诞节倒计时网页的制作过程jQuery+css3制作精美的2020圣诞节倒计时页面动画特效代码
- 使用css3实现的tab选项卡代码分享多种动画形式的TABs选项卡的CSS3代码CSS3+jQuery实现切换过程中带有动态滑动展示的选项卡Tab效果jQuery+css3实现的超酷无图片圆角tab选项卡切换效果基于jquery+css3实现的Tabs带图形按钮选项卡切换纯CSS3实现的干净清爽tab选项卡切换特效源码
- 使用css3实现的windows8开机加载动画CSS3制作了一个动画导航效果(鼠标悬浮会放大)基于jQuery+CSS3模拟印钞出钞动画效果CSS3的动画泡沫按钮效果基于CSS3技术的生成动画效果 Loading加载效果的各种小图片你正在寻找的CSS3 动画技术 css3气泡 css3关键帧动画创建的动态通知气泡如何使用html5与css3完成google涂鸦动画
- css3的transform中scale缩放详解css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- 详谈IE条件注释面向XHTML的IE条件注释IE的有条件注释优点和缺点css 条件注释区分非IE浏览器 针对主流浏览器的CSS-HACK写法及IE常用条件注释 ie10 css hack 条件注释等兼容方式整理浏览器兼容之旅第一站:如何在页面中创建IE条件注释条件注释判断浏览器(ie系列)使用条件注释判断 IE 浏览器版本适用于IE5.0及以上版本
- css3实例教程 一款纯css3实现的发光屏幕旋转特效css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- css3的transform造成z-index无效解决方案div层调整z-index属性在IE中无效原因分析及解决方法ActiveX插件的Z-Index属性无效问题解决IE6 select z-index无效,遮挡div bug的解决方法div层调整z-index属性无效原因分析及解决方法
- 浅谈CSS伪类与伪元素详解如何使用CSS3中的结构伪类选择器和伪元素选择器解析CSS中的伪元素及其与伪类的区别详解CSS中的伪类与伪元素及二者间的区别CSS伪类和伪元素的区别详解css3 伪元素和伪类选择器详解CSS伪类/伪元素选择器整理css伪类伪元素域高级选择器的介绍CSS伪类与CSS伪元素的区别及由来具体说明浅谈CSS 伪元素&伪类的妙用
- 深入了解float与inline-blockCSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题