LESS碎语

推荐在Brackets安装"LESS AutoCompile"插件,当保存less文件会自动生成或保存相应的css文件。

变量

以@开头声明变量,并且对变量进行分类,比如颜色变量、字体大小变量、模版变量、布局变量,等等。比如:

@fontSize:#000;

嵌套

<div class="container">
    <p>hello</p>
</div>

.container{
    font-size: @fontSize;
    p {
        text-align:center;

&:after{
            content: ‘hel‘;
        }
    }
}

以上有3层嵌套,分别是.container, p, &:after(&表示p本身)。

Mixins,或者叫css rule

把一个类作为另一个类的样式值。

● 基本

.myRule {
    text-align: center;
}

p {
    .myRule;
}

● 定义一个带变量的类

.border-radius(@radius){
    -webkit-border-radius:@radius;
    -moz-border-radius:@radius;
    -o-border-radius:@radius;
    -ms-border-radius:@radius;
    border-radius: @radius;
}

变量可以有一个默认值:

.border-radius(@radius:10px){
    -webkit-border-radius:@radius;
    -moz-border-radius:@radius;
    -o-border-radius:@radius;
    -ms-border-radius:@radius;
    border-radius: @radius;
}

定义多个变量也是允许的:

.border(@width:2px, @style:solid,@color:@fontColor){
   
}

然后使用这个带变量的类,就像使用函数一样。

img {
    .border-radius(5px);
}

● 可以把一个Mixin放在另一个Maxin中,比如:

.myRule {
    text-align: center;
    .border-radius(5px);
}

● 根据变量不同的值使用不同的样式

.set-text-color(@bg-color) when (lightness(@bg-color) >= 50%){
    color: @dark;
    background: @bg-color;
}

.set-text-color(@bg-color) when (lightness(@bg-color) < 50%){
    color: @light;
    background: @bg-color;
}

然后这样应用:

.box-1{
    .set-text-color(darken(@template_color,20%));
}

操作符

@padding:10px;

.container{
   
    padding: @padding+10;
}

可以用+,-,*,/。

less的内置函数

● 让颜色更深:darken(@color,20%);
● 获取颜色值:color("fff"),返回#aaa
● 获取图片大小:image-size("temp.png"),返回10px 10px
● 获取图片宽度:image-width("temp.png")
● 获取图片高度:image-height("temp.png")
● 单位转换:convert(9s, "ms"), convert(14cm, mm)
● 链接资源 data-uri(mimetype,url),第一个参数可省

例子:data-uri(‘../data/temp.jpg‘)
CSS输出:url(‘data:image/jpeg;base64,bm90IGFjdHVhbGx5IGEganBlZyBmaWxlCg==‘);
浏览器中输出:url(‘../data/temp.jpg‘);

例子:data-uri(‘image/jpeg;base64‘, ‘../data/image.jpg‘);
CSS输出:url(‘data:image/jpeg;base64,bm90IGFjdHVhbGx5IGEganBlZyBmaWxlCg==‘);

例子:data-uri(‘image/svg+xml;charset=UTF-8‘, ‘image.svg‘);
CSS输出:url("data:image/svg+xml;charset=UTF-8,%3Csvg%3E%3Ccircle%20r%3D%229%22%2F%3E%3C%2Fsvg%3E");

● 默认值 default()

例子:在CSS规则中,default()表示true

html:

<div class="container">
        <div class="box box1">box1</div>
        <div class="box box2">box2</div>
        <div class="box box3">box3</div>
    </div>

less:

.box{
    width: 100px;
    height: 100px;
    border: 1px solid black;
}

.backcolor(red){background-color: red;}
.backcolor(green){background-color: green;}
.backcolor(@color) when (default()){background-color: @color;}

.box1{
    .backcolor(red);
}

.box2{
    .backcolor(green);
}

.box3{
    .backcolor(orange);
}

css:

.box {
  width: 100px;
  height: 100px;
  border: 1px solid black;
}
.box1 {
  background-color: red;
}
.box2 {
  background-color: green;
}
.box3 {
  background-color: orange;
}

● 拼接数值和单位:unit(5, px), 输出:5px
● 去掉单位获取值:unit(5px),输出5
● 获取数值单位中的单位:get-unit(5px)
● 获取封顶整型值:ceil(2.4)
● 获取底板整型值:floor(2.6)
● 获取浮点数的百分比:percentage(0.5)
● 四舍五入:round(1.67),输出2;规定精度:round(1.67,1),输出1.7
● 平方根:sqrt(25cm)
● 绝对值:abs(-5px)
● 是否是整数:isnumber()
● 是否是字符串:isstring()
● 是否是颜色: iscolor()
● 是否是CSS关键字:iskeyword
● 是否是url: isurl()
● 是否是像素:ispixeel()
● 是否加重字体:isem()
● 是否百分比:ispercentage()
● 创建颜色:rgb(90,129,32)
● 创建有透明度的颜色:rgba(90,129,32,0.5),css输出rgba(90, 129, 32, 0.5);argb(rgba(90, 23, 148, 0.5));输出#805a1794

更多参考: http://lesscss.org/functions/

@import

引入外部css文件与当前css文件合并。

@import "vendors/bootstrap/bootstrap.less";
@import "vendors/bootstrap/bootstrap.css";

时间: 2024-10-12 15:52:39

LESS碎语的相关文章

jQuery碎语(4) 实用函数

6.实用函数 ● 修剪字符串 $('#id').val($.trim($('#someid').val())) ● 遍历集合 可能这样写: var anArray = ['one','two']; for(var n = 0; n < anArray.length; n++){ } 还有可能这样写: var anObject = {one: 1, two: 2}; for(var p in anObject){ } 但有了$.each函数后,就可以这样写了: var anArray = ['on

jQuery碎语(2) 事件

4.事件 ● 通过方法名给元素绑定事件: $('li').click(function(event){}) ● 通过bind方法给元素绑定事件: $('li') .bind('click',function(event){}) .bind('click',function(event){}) 可见,通过bind,可以给元素绑定多个事件. ● 事件的命名空间 为什么需要事件命名空间? →假设,先给li元素绑定2个click事件. $('li') .bind('click',function(eve

jQuery碎语(3) 动画特效

5.动画特效 ● 自制折叠内容块 内容块如下 <div class="module"> <div class="caption"> <span>标题</span> <img src="rollup.gif" alt="rollup" title="rolls up this module"/> </div> <div class=

jQuery碎语(1) 基础、选择要操作的元素、处理DOM元素

1.基础 jquery对象集: $():jquery对象集合 获取jquery对象集中的元素: 使用索引获取包装器中的javascript元素:var temp = $('img[alt]')[0] 使用jquery的get方法获取jquery对象集中的javascript元素:var temp = $('img[alt]').get(0) 使用jquery的eq方法获取jquery对象集中的jquery对象元素: $('img[alt]').eq(0) $('img[alt]').first(

做互联网服务的一些心得碎语

写在前面的话:日常反思,碎语而已,没有逻辑线,也没有时间线,有些已经过时 提供任何信息服务,首先搞明白的是这个信息业务主体,有体才有用,有内容才有形式. 平台本身提供的是信息服务,既不是技术服务,也不是线下直接服务.技术服务通过信息服务这个本体承载提升线下直接服务品质的目标. 做事要跳出个人利益的圈囿,甚至要跳出团体局部短期利益的圈囿 太极拳推手要诀:舍己从人.随机应变.因势利导.引进落空.避实就虚.运化自如.做互联网服务也要有这样的思维 退就是一种进,进就是一种退--闭环螺旋劲 要抓具体业务切

缓存碎语二

缓存很多条数据,但只读取其中的一部分数据,如何处理? 比如在缓存中保存了100条数据,但读取分页数据,比如每次分页只读取10条数据.这种情况下,可以把这100条数据拆分成10次分别保存起来.每一个缓存项的key需要特别的设计,比如:01-10-products, 02-10-products...... 如何避免缓存一些不需要的数据? 比如: public class Teacher { public int Id{get;set;} public string Name{get;set;} p

Bootstrap碎语

这里记录下某段时间Bootstrap的零散碎片. 1.有关Bootstrap的参考网站: ● 官方:http://getbootstrap.com/● 主题:http://bootswatch.com/● Font-Awsome: http://fortawesome.github.io/Font-Awesome/● 幻灯片:lokeshdhakar.com/projects/lightbox2/● 幻灯片:ashleydw.github.io/lightbox/● 表格字段排序:http://

缓存碎语一

如果按存储的地方来分类,缓存分为哪些? 分为本地缓存和分布式缓存.本地缓存就是把数据保存应用程序所在的那台机器的内存中:而分布式缓存是把数据放在缓存服务器中,这个缓存服务器有可能是和应用服务器在同一台机器,这时候的是跨进程访问,如果缓存服务器和应用程序服务器不在同一台机器,这时候就可能会设计到跨域跨进程访问了. 缓存通过何种方式来找到缓存中的数据? 表面上是通过键来找到对象,实际是通过对象的引用在内存中查找到数据对象的. 修改缓存对象和修改数据库数据是一回事吗? 千万不要认为修改缓存对象就是修改

抓包工具之—charles碎言碎语

一.Charles常见使用场景: 1.Charles是跨平台的抓包工具,支持Windows,mac或Linux平台: 2.获取请求信息.测试接口时,若接口文档中的参数不清楚或没有接口文档时,可以通过抓包获取请求信息.URL.cookie或是否加入Header等. 3.定位问题.页面无响应时,可通过抓取信息判断是页面问题还是服务器端响应问题(判断前端或后台服务问题). PS:HTTPS请求是经过加密的,因此是不能看到请求信息的. 二.实例一个场景:截获网络请求并修改请求信息,返回页面.以bj.58