码迷,mamicode.com
首页 > Web开发 > 详细

前端CSS编程之道-LESS

时间:2015-12-23 11:01:28      阅读:249      评论:0      收藏:0      [点我收藏+]

标签:

由于前端css编写繁琐,最近开始学习LESS,用LESS编写文件.less文件可以直接编译成我们要的.css文件

学习Less 我下面是我练习时的截图,希望小伙伴也能动手自己写一下,而不是复制粘贴模式学习。动手敲能体会不一样

1.下载国内的koala的预处理器,可以自动把less编译成css

2.使用sublime安装插件,推荐这种方式,因为我们是前端攻城狮

变量

用@来声明变量

技术分享

输出

技术分享

发现变量还可以引入变量的。可以看@ref的特别使用。

如果对同一个变量定义的话,在当前作用域中最后一次定义的将被使用。这个与CSS的机制类似

技术分享

输出

技术分享

 

变量不一定要声明的时候才能使用的,是按需加载的

技术分享

输出

技术分享

 

混合(Mixins)

在less中我们可以定义一些通用的属性集为一个class,然后在另外一个class中去调用这些属性

技术分享

输出

技术分享

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

带参数混合

技术分享

输出

技术分享

这个我特别喜欢,因为他可以做到几个浏览器的兼容。哈哈~~不过当你用sublime Text的

时候,有一个插件,可以直接帮你生成这些前缀。很强大很牛逼的东西 sublime-autoprefixer 大家可以去了解一下

参数混合可以带默认值

技术分享

输出

技术分享

 

倘若你想隐藏通用集合,那么你可以声明一个不带参数的混合

技术分享

输出

技术分享

 

多参数混合

有点比较复杂,不过我们不要把他使用太复杂就好

技术分享

输出

技术分享

 

希望大家看懂,第一个混合被调用了,第二个也被调用了,第三个没有被调用

1.因为只有一个参数的一定会调用你声明的第一个混和 .mixin,

2.当你第二个参数有默认值,那么使用一个参数,第二个参数就会默认的,所以也会调用

3.声明的第三个声明的混合没有被调用,因为第二个参数没有默认值。

 

在看下面的效果,调用的混合使用两个参数

技术分享

输出

技术分享

看见了吧

1.第一个声明的混合没有被调用

2.第二个声明被调用了

3.第三个声明也被调用了

 *在这里说明一下,多参数可以用逗号分隔也可以用分号分隔,最好使用分号分隔

@arguments变量

对于多个参数的混合,我们可以使用@arguments变量

技术分享

输出

技术分享

大家还可以去了解一下@rest变量的使用,在这里就不在这里讲解了

!important关键字使用

技术分享

输出

技术分享

Guards模式的使用

 技术分享

输出

技术分享

大家可以看见@_可以代表任何参数,可以放入.border集合共有的属性,还有一种实现方式

就是把color的参数也放入到.border(thick,@color:#fff)这样也可以,希望大家多思考。

Gurads的表达式

这个有点像编程中if/else

技术分享

 

输出

技术分享

 

Guards还支持运算符操作 下面是or的操作

技术分享

 

输出

技术分享

也可以这样是下面这种情况

技术分享

 

还可以调用函数来判断,大家看下面就不用详解了吧

技术分享

几种检查类型的函数和单位的函数

技术分享

 

大家可以去了解一下 ,when的and和取非

技术分享

希望大家能掌握好。

 

嵌套规则

 技术分享

输出

技术分享

另一种串联的

技术分享

 

 

输出

技术分享

 

 

注意 & 符号的使用 — 如果你想写串联选择器,而不是写后代选择器,就可以用到 & 了。这点对伪类尤其有用如 :hover:focus 

还有就是&的高级用法

技术分享

 

 

输出

技术分享

 

运算

技术分享

希望大家知道怎么使用了,这个很简单,不过现在的严格模式,希望都加上括号

 

命名空间

其他的类可以直接按命名空间来引入

技术分享

输出

技术分享

 Media Query查询

技术分享

输出

技术分享

前端CSS编程之道-LESS

标签:

原文地址:http://www.cnblogs.com/kevinlifeng/p/5069069.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!