【Less中的变量】
  1、声明变量:@变量名:变量值;
     使用变量:@变量名
@length:100px;
@color:yellow;
@opa:0.5;
  >>>Less中变量的类型:
    ①数字类:1 10px
    ②字符串:无引号字符串 red 有引号字符串 "haha"
    ③颜色类:red #000000 rgb()
    ④值列表类:用逗号或空格分隔10px solid red
  >>>变量使用原则:多次频繁出现的值、需要修改的值,设为变量。
#div1{
width: @length;
height: @length;
background-color: @color;
opacity: @opa;
.borderRadius;
.setMargin(top_,10px);
}

  

2、混合(Mixins)
  ①无参混合
   声明:.name{}; 选择器中调用 .name
  ②带参混合
   无默认值声明:.name(@param){} 调用:.name(parValue);
   有默认值声明:.name(@param:value){} 调用:.name(parValue); parValue可省
    >>>如果声明时,参数没有默认值,则调用时必须赋值,否则报错
    >>>无参混合,会在css中编译出同名的class选择器;有参的不会
3、Less的匹配模式
  使用混合进行匹配,类似于if结构;
  声明:.name(条件一,参数){} .name(条件二,参数){} .name(条件三,参数){} .name(@_,参数){}
.setMargin(top_,@width){
margin-top: @width;
}
.setMargin(bottom_,@width){
margin-bottom: @width;
}
.setMargin(@_,@width){
padding: 10px;
}
  调用:.name(条件值,参数值);
.setMargin(top_,10px);
  匹配规则:根据调用时提供的条件值,去寻找与之匹配的"Mixins"执行。其中@_表示永远需要执行的部分。
4、Less中的运算
  + - * /
  颜色计算时,红绿蓝分三组计算。组内可进位,组间互不干涉

【Less中的嵌套】
  1、嵌套默认是后代选择器,如果需要子代选择器,则在子代前面加>
  2、& 表示上一层,&:hover 表示上一层的hover事件
section{
p{
color: blueviolet;
background-color: #00FFFF;
text-align: center;
}
ul{
padding: 0px;
list-style: none;
li{
float: left;
margin: 10px;
width: 100px;
border: 3px solid #00CED1;
text-align:center;
&:hover{
background-color: cornflowerblue;
color: white;
}
};
}
}
 
【Sass中的变量】
  1、声明变量:$变量名:变量值
  2、变量在字符串中嵌套,需使用#{}包裹
border: #{$i}px solid red; 
  3、Sass中的运算:会将单位也进行运算。使用时需注意最终单位
    10px*10px=100px*px
  4、混合宏、继承、占位符
    ①混合宏:声明@mixin name($param:value){}
@mixin hong($color:yellow){
color: $color;
}

         调用@include name(value);

@include hong;

  

    >>>声明时可以有参,也可无参;可带默认值,也可不带;但是调用时必须符合声明规范,同less
    >>>优点:可以传参
    >>>缺点:会将混合宏中代码copy到对应的选择器中,产生冗余代码
    ②继承:声明:.class{}
.class{
padding: 10px;
}

        调用:@extend.class;

@extend .class;

    >>>优点:继承的相同代码,可以提取到并集选择器;不会生成同名的class选择器

    >>>缺点:无法进行传参
  综上所述:当需要传递参数时,用混合宏;当有现成class时用继承;当不需要class时,用占位符
  5、if条件结构
    @if 判断条件{}
    @else{}
  6、for循环结构
    @for $i from 1 to 10{} 不含10
    @for $i from 1 through 10{} 包含10
@for $i from 1 through 4{
.border#{$i}{
border: #{$i}px solid red;
}
}

  7、while循环结构

    $j:1,
    @while 判断条件{}
$j:1;
@while $j<4{
.while#{$j}{
border:#{$j}px solid red;
}
$j:$j+1;
}

  8、each循环遍历

    @each $item in a,b,c,d{}
  9、函数
    @function func($name){}

@function func($length){
$length:$length*5;
@return $length;
}

  【Sass中的嵌套】

  1、选择器嵌套 ul{ li{} } 后代
    ul{ >li{} } 子代
    &表示上一层 div{ ul {li{ &=="div ul li" } } }
  2、属性嵌套:属性名与{之间必须有: 例如 border:{color:red;}
  3、伪类嵌套:ul{li{ &:hover{ "ul li:hover " } } }

    

section{
p{
color: #2173B6;
background-color: #00FFFF;
}
ul{
padding: 0px;
list-style: none;
li{
float: left;
width: 100px;
text-align: center;
margin: 10px;
border: {
color: #4E81BD;
style:solid;
width: 10px;
};
&:hover{
background-color: #6495ED;
color: white;
}
}
}
}

  

 

Less和Sass的使用的更多相关文章

  1. wepack+sass+vue 入门教程(三)

    十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...

  2. wepack+sass+vue 入门教程(二)

    六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...

  3. wepack+sass+vue 入门教程(一)

    一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...

  4. 前端CSS预处理器Sass

    前面的话   "CSS预处理器"(css preprocessor)的基本思想是,用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件.SASS是一种CSS的开发工 ...

  5. SASS教程sass超详细教程

    SASS安装及使用(sass教程.详细教程) 采用SASS开发CSS,可以提高开发效率. SASS建立在Ruby的基础之上,所以得先安装Ruby. Ruby的安装: 安装 rubyinstaller- ...

  6. Sass之坑Compass编译报错

    前段时间在使用Compass时遇到了其为难处理的一个坑,现记录到博客希望能帮助到各位. 一.问题: 利用Koala或者是gulp编译提示如下,截图为koala编译提示错误: 二.解决办法 从问题截图上 ...

  7. emmet,jade,haml, slim,less,sass,coffeescript等的实战优缺点

    摘要: 文章背景,来自于群内周五晚上的一次头脑风暴式的思维碰撞交流活动. 随着前端技术的蓬勃发展, 各种新技术随着生产力的需要不断的涌入我们的视野, 那今天探讨的话题是这些新时代的前端兵器谱: 一. ...

  8. Sass用法指南

    写在前面的话:随着CSS文件越来越大,内容越来越复杂,对其进行很好的维护将变的很困难.这时CSS预处理器就能够帮上大忙了,它们往往拥有变量.嵌套.继承等许多CSS不具备的特性.有很多CSS预处理器,这 ...

  9. PostCSS深入学习: PostCSS和Sass、Stylus或LESS一起使用

    如果你喜欢使用PostCSS,但又不想抛弃你最喜欢的预处理器.不用担心,你不需要作出二选一的选择,你可以把PostCSS和预处理器(Sass.Stylus或LESS)结合起来使用. 有几个PostCS ...

  10. Sass:初识Sass与Koala工具的使用

    一.下载Koala(找到合适的系统版本)并安装 二.先新建一个css文件夹,并在里面新建一个文本文档(.txt),将其命名为demo.scss 三.打开Koala,将css文件夹拽进来,可以修改一下输 ...

随机推荐

  1. MVC支付宝PC网站接口对接

    PC网站支付接口,请参考支付宝官方文档:https://b.alipay.com/signing/productSet.htm?navKey=all 1.需要提供签约账号.商户密钥 2.代码实现: 支 ...

  2. Android开发之获取xml文件的输入流对象

    介绍两种Android开发中获取xml文件的输入流对象 第一种:通过assets目录获取 1.首先是在Project下app/src/main目录下创建一个assets文件夹,将需要获取的xml文件放 ...

  3. JAVA源码剖析(容器篇)HashMap解析(JDK7)

    Map集合: HashMap底层结构示意图: HashMap是一个“链表散列”,其底层是一个数组,数组里面的每一项都是一条单链表. 数组和链表中每一项存的都是一“Entry对象”,该对象内部拥有key ...

  4. [cookie篇]从cookie-parser中间件说起

    当我们在写web的时候,难免会要使用到cookie,由于node.js有了express这个web框架,我们就可以方便地去建站.在使用express时,经常会使用到cookie-parser这个插件. ...

  5. strtol函数 将字符串转换为相应进制的整数

    转自http://hi.baidu.com/qwpsmile/blog/item/9bc44efa4f41018a9f514637.html +----------------+|      strt ...

  6. Git 入门和常用命令详解

    git 使用使用教程   git 使用简易指南  常用 Git 命令清单 下载   https://git-scm.com/downloads 工作流 本地仓库由三部分组成. 工作区:保存实际的文件( ...

  7. 搭建ubuntu版hadoop集群

    用到的工具:VMware.hadoop-2.7.2.tar.jdk-8u65-linux-x64.tar.ubuntu-16.04-desktop-amd64.iso 1.  在VMware上安装ub ...

  8. GDOI2014模拟pty爬山(mountain)

    pty爬山(mountain) 在Pty学校附近,有一座名之为岳之麓的高山.Pty很喜欢和(哔--)一起爬山.山的平面模型如下:山由一个顶点集:A1,A2-An给定,保证Ai的x单调递增.我们将Ai和 ...

  9. 老李推荐:第14章1节《MonkeyRunner源码剖析》 HierarchyViewer实现原理-面向控件编程VS面向坐标编程

    老李推荐:第14章1节<MonkeyRunner源码剖析> HierarchyViewer实现原理-面向控件编程VS面向坐标编程   poptest是国内唯一一家培养测试开发工程师的培训机 ...

  10. (iOS)关于zbar扫描条形码,所搭载的设备

    四个月之前写的,现在发出来. 最近在开发一款程序的时候,功能要求扫描条形码. 现在最流行的扫描条形码的开源代码有zbar和zxing两种,可以支持多种一维和二维码. 之前了解过zbar,所以这次试用z ...