Less是一种动态的样式语言。Less扩展了CSS的动态行为,比如说,设置变量(Variables)、混合书写模式(mixins)、操作(operations)和功能(functions)等等,最棒的是,Less使用了现有的CSS语法,也就是说,你可以直接把你现成的样式文件“style.css”直接改成“style.less”,他也能正常工作。

编译less

1.使用js

<link rel="stylesheet/less" type="text/css" href="css/style.less" >
<script type="text/javascript" src="js/less-1.3.3.min.js" data-env="development" ></script >//网上可下载
2.Koala编译工具
koala是一个前端预处理器语言图形编译工具,支持Less、Sass、Compass、CoffeeScript,帮助web开发者更高效地使用它们进行开发。跨平台运行
官网地址http://koala-app.com/index-zh.html
3.使用第三方工具gulp grunt等
less语法 变量
//less
@color:#333;
header{
color:@color;
}
/*css*/
header{
color:#333333;
}

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

//less
.bd50{
border-radius: 50%;
}
.yuan{
width:100px;
height:100px;
background:red;
.bd50
}
/*css*/
.yuan{
width:100px;
height:100px;
background:red;
border-radius: 50%;
}
//html代码
<div class="yuan"></div>
 效果

带参数混合--像函数一样定义一个带参数的属性集合,然后在另一个class中去调用这些属性。

//less
/*classA:设置圆角角度为50px*/
.radius(@radius: 50px) {
border-radius: @radius;
-webkit-border-radius: @radius;
-moz-border-radius: @radius;
}
/*classB:设置阴影颜色大小*/
.boxShadow(@boxShadowColor:0 0 10px rgba(0, 204, 204, .5)){
-webkit-box-shadow:@boxShadowColor;
-moz-box-shadow:@boxShadowColor;
box-shadow:@boxShadowColor;
}
/*classC:调用A、B*/
.tableBorder{
border : 5px solid 5px solid #ffff00;
background: #ffc0cb;
width: 200px;
height: 200px;
padding: 0;
margin:0;
text-align: center;
line-height: 200px;
.boxShadow;
/*在classC中调用classA、B 带值带括号 括号内给值,执行括号内的数据*/
.radius();
}
/*css*/
.tableBorder {
border: 5px solid #ffff00;
background: #ffc0cb;
width: 200px;
height: 200px;
padding: 0px;
margin: 0px;
text-align: center;
line-height: 200px;
-webkit-box-shadow: 0 0 10px rgba(0, 204, 204, 0.5);
-moz-box-shadow: 0 0 10px rgba(0, 204, 204, 0.5);
box-shadow: 0 0 10px rgba(0, 204, 204, 0.5);
border-radius: 50px;
-webkit-border-radius: 50px;
-moz-border-radius: 50px;
}
 //html代码
<div class="tableBorder">我是一个带参数混合的正方形</div>

效果

 @arguments变量--@arguments包含了所有传递进来的参数. 如果你不想单独处理每一个参数的话就可以像这样写:

//less
.arguments{
width: @width200;
height: @width200;
margin: 30px;
.box-Shadow();
}
.box-Shadow(@x:0,@y:0,@blur:1px,@color: rgba(215, 22, 185, .5)){
//包含传进来的所有参数
box-shadow: @arguments;
-moz-box-shadow: @arguments;
-webkit-box-shadow: @arguments;
}
/*css*/
.arguments {
width: 200px;
height: 200px;
margin: 30px;
box-shadow: 0 0 1px rgba(215, 22, 185, 0.5);
-moz-box-shadow: 0 0 1px rgba(215, 22, 185, 0.5);
-webkit-box-shadow: 0 0 1px rgba(215, 22, 185, 0.5);
}
//html代码
<div class="arguments">arguments变量</div>

嵌套--可以在一个选择器中嵌套另一个选择器来实现继承,这样很大程度减少了代码量,并且代码看起来更加的清晰。

//less

 .list{
width: 100%;
padding: 0;
margin: 30px auto;
list-style: none;
li{
height: 30px;
line-height: 30px;
margin-bottom: 5px;
background: pink;
padding: 0 10px;
//这样写也可以 但是要进行更深层次的匹配 影响效率
/*a{
color: #666;
text-decoration: none;
padding-left: 20px;
}*/
}
a{
color: #666;
text-decoration: none;
//&:代表他的上一层选择器
&:hover{
color: #3a87ad;;
text-decoration: underline;
}
} span{
float: right;
}
}
/*css*/
.list {
width: 100%;
padding: 0;
margin: 30px auto;
list-style: none;
}
.list li {
height: 30px;
line-height: 30px;
margin-bottom: 5px;
background: pink;
padding: 0 10px;
}
.list a {
color: #5bc0de;
text-decoration: none;
}
.list a:hover {
color: #3a87ad;;
text-decoration: underline;
}
.list span {
float: right;
}
//html代码
<div class="qiantao">
<ul class="list">
<li><a href="#">这是一个测试嵌套的代码</a><span>2012-04-02</span></li>
<li><a href="#">这是二个测试嵌套的代码</a><span>2012-04-02</span></li>
<li><a href="#">这是三个测试嵌套的代码</a><span>2012-04-02</span></li>
</ul>
</div>

匹配模式--有些情况下,我们想根据传入的参数来改变混合的默认呈现,比如下面这个例子:

//less
//朝上
//宽度默认5,颜色默认灰色
.triangle(top,@w:100px,@c:#ccc){
border-width: @w;
border-color: transparent transparent @c transparent;
border-style: dashed dashed solid dashed;
}
//朝下
.triangle(bottom,@w:100px,@c:#ccc){
border-width: @w;
border-color:@c transparent transparent transparent;
border-style:solid dashed dashed dashed;
}
//朝左
.triangle(left,@w:100px,@c:#ccc){
border-width: @w;
border-color: transparent @c transparent transparent ;
border-style: dashed solid dashed dashed ;
}
//朝右
.triangle(right,@w:100px,@c:#ccc){
border-width: @w;
border-color: transparent transparent transparent @c ;
border-style: dashed dashed dashed solid;
}
//特殊匹配模式 不管匹配谁都会执行@_的内容
.triangle(@_,@w:100px,@c:#ccc){
width: 0px;
height: 0px;
overflow: hidden;
}
.sanjiao{
.triangle(left);
}
/*css*/
//由于调用的“left”,所以只会编译left的样式
.sanjiao {
border-width: 100px;
border-color: transparent #cccccc transparent transparent;
border-style: dashed solid dashed dashed ;
width: 0px;
height: 0px;
overflow: hidden;
}
 //html代码
<div class="sanjiao"></div>

less简介的更多相关文章

  1. ASP.NET Core 1.1 简介

    ASP.NET Core 1.1 于2016年11月16日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强.这个版本包含了多个新的中间件组件.针对Windows的WebListener服 ...

  2. MVVM模式和在WPF中的实现(一)MVVM模式简介

    MVVM模式解析和在WPF中的实现(一) MVVM模式简介 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在 ...

  3. Cassandra简介

    在前面的一篇文章<图形数据库Neo4J简介>中,我们介绍了一种非常流行的图形数据库Neo4J的使用方法.而在本文中,我们将对另外一种类型的NoSQL数据库——Cassandra进行简单地介 ...

  4. REST简介

    一说到REST,我想大家的第一反应就是“啊,就是那种前后台通信方式.”但是在要求详细讲述它所提出的各个约束,以及如何开始搭建REST服务时,却很少有人能够清晰地说出它到底是什么,需要遵守什么样的准则. ...

  5. Microservice架构模式简介

    在2014年,Sam Newman,Martin Fowler在ThoughtWorks的一位同事,出版了一本新书<Building Microservices>.该书描述了如何按照Mic ...

  6. const,static,extern 简介

    const,static,extern 简介 一.const与宏的区别: const简介:之前常用的字符串常量,一般是抽成宏,但是苹果不推荐我们抽成宏,推荐我们使用const常量. 执行时刻:宏是预编 ...

  7. HTTPS简介

    一.简单总结 1.HTTPS概念总结 HTTPS 就是对HTTP进行了TLS或SSL加密. 应用层的HTTP协议通过传输层的TCP协议来传输,HTTPS 在 HTTP和 TCP中间加了一层TLS/SS ...

  8. 【Machine Learning】机器学习及其基础概念简介

    机器学习及其基础概念简介 作者:白宁超 2016年12月23日21:24:51 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结 ...

  9. Cesium简介以及离线部署运行

    Cesium简介 cesium是国外一个基于JavaScript编写的使用WebGL的地图引擎,一款开源3DGIS的js库.cesium支持3D,2D,2.5D形式的地图展示,可以自行绘制图形,高亮区 ...

  10. 1.Hibernate简介

    1.框架简介: 定义:基于java语言开发的一套ORM框架: 优点:a.方便开发;           b.大大减少代码量;           c.性能稍高(不能与数据库高手相比,较一般数据库使用者 ...

随机推荐

  1. iOS多线程实现2-NSThread

    NSThread是轻量级的多线程开发,OC语言编写,更加面向对象,使用起来也并不复杂,但是使用NSThread需要自己管理线程生命周期.在iOS开发中很少使用它来创建一个线程,但是经常使用它做一些延时 ...

  2. 【iOS】屏幕适配之NSLayoutConstraint

    前言 如何实现一张图片在iPhone和iPad上显示不同的尺寸,我了解到一般有三种办法:直接手写代码动态添加约束:把NSLayoutConstraint关联到ViewController里再viewD ...

  3. 【原】Github系列之二:开源 一行代码实现多形式多动画的推送小红点WZLBadge(iOS)

    更新日志 V1.2 2015.09.25 1.UITabBarItem badge is supproted; 2.Enable change badge properties when badge ...

  4. HashSet 浅析示例

    * 1.继承自抽象类 AbstractSet,实现接口 Set.Cloneable.Serializable: * 2.元素无顺序: * 3.元素不可重复: * 4.采用哈希算法插入数据,插入速度快: ...

  5. #数据技术选型#即席查询Shib+Presto,集群任务调度HUE+Oozie

    郑昀 创建于2014/10/30 最后更新于2014/10/31   一)选型:Shib+Presto 应用场景:即席查询(Ad-hoc Query) 1.1.即席查询的目标 使用者是产品/运营/销售 ...

  6. TNS-12502: TNS:listener received no CONNECT_DATA from client

    检查我们的一台ORACLE数据库的监听日志发现有不少TNS-12502错误信息.如下所示 TNS-12502: TNS:listener received no CONNECT_DATA from c ...

  7. 【hive】——Hive初始了解

    1.没有接触,不知道这个事物是什么,所以不会产生任何问题.2.接触了,但是不知道他是什么,反正我每天都在用.3.有一定的了解,不够透彻.那么hive,1.我们对它了解多少?2.它到底是什么?3.hiv ...

  8. 网页实时聊天之PHP实现websocket

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

  9. Pause/Resume Instance 操作详解 - 每天5分钟玩转 OpenStack(34)

    本节通过日志详细分析 Nova Pause/Resume 操作. 有时需要短时间暂停 instance,可以通过 Pause 操作将 instance 的状态保存到宿主机的内存中.当需要恢复的时候,执 ...

  10. Eclipse不自动编译java文件的终极解决方案

    最近我的eclipse经常犯傻,项目中总是有很多,启动项目也是没有启动类.查了下项目中生成的class文件,我靠竟然没有,或者还是以前的.原来是eclipse犯傻了,它没帮我自动编译java文件.一般 ...