在介绍less和sass的区别之前,我们先来了解一下他们的定义:

一、Less、Sass/Scss是什么?

1、Less:

是一种动态样式语言. 对CSS赋予了动态语言的特性,如变量、继承、运算、函数。

Less 既可以在客户端上运行 (支持IE 6+, Webkit, Firefox),也可在服务端运行。

2、Sass:

是一种动态样式语言,Sass语法属于缩排语法,

比css比多出好些功能(如变量、嵌套、运算,混入(Mixin)、继承、颜色处理,函数等),更容易阅读。

Sass与Scss是什么关系?

Sass的缩排语法,对于写惯css前端的web开发者来说很不直观,也不能将css代码加入到Sass里面,因此sass语法进行了改良,Sass 3就变成了Scss(sassy css)。与原来的语法兼容,只是用{}取代了原来的缩进。

二、less和sass的相同之处

Less和Sass在语法上有些共性,比如下面这些:

1、混入(Mixins)——class中的class;

2、参数混入——可以传递参数的class,就像函数一样;

3、嵌套规则——Class中嵌套class,从而减少重复的代码;

4、运算——CSS中用上数学;

5、颜色功能——可以编辑颜色;

6、名字空间(namespace)——分组样式,从而可以被调用;

7、作用域——局部修改样式;

8、JavaScript 赋值——在CSS中使用JavaScript表达式赋值。

三、less和sass的区别

Less和Sass的主要不同就是他们的实现方式。

Less是基于JavaScript,是在客户端处理的。

Sass是基于Ruby的,是在服务器端处理的。

关于变量在Less和Sass中的唯一区别就是Less用@,Sass用$。

1、Less:

【两种注释方式】

①//less中的注释,但这种不会被编译

/*
 * 这也是less中的注释,但是会被编译
 */

【less中的变量】

1、声明变量:

@变量名:变量值;

使用变量: @变量名

>>>less中变量的类型:

①数字类 1 10px

②字符串:无引号字符串 red ;有引号字符串 "haha"

③颜色类:red #000000 rgb()

④值列表类型:用逗号和空格分隔 10px solid red

@length: 100px;
@color:red;
@opa:0.5;
@border:10px solid red;
.borderRadius(@brWidth:10px){
  border-radius: @brWidth;
}
.setMargin(lefts,@width){
  margin-left:@width;
}

>>>变量使用原则:

多次频繁出现的值、需要修改的值,设为变量

2、混合(MiXins)

①无参混合

声明:.name{}

选择器中调用:.name;

②代参混合

无默认值

声明:.name(@param){}

调用:.name(parValue);

有默认值

声明:.name(@param:value){}

调用:.name(parValue); //parValue可省

>>>如果声明时,参数没有默认值,则调用时必须赋值,否则报错!

>>>无参混合,会在css中编译除同名的class选择器,有参的不会

3、less的匹配模式:

使用混合进行匹配,类似于if结构

声明:

.name(条件一,参数){} 

.name(条件二,参数){} 

.name(@_,参数){}

调用:

.name(条件值,参数值);

匹配规则:根据调用时提供的条件值去寻找与之匹配的"MiXins"执行,其中@_表示永远需要执行的部分

4、less中的运算

+ - * / 可带、可不带单位

颜色运算时,红绿蓝分三组计算,组内可进位,组间互不干涉

5、包含了传进来的所有参数:

border:@arguments;

6、less中的嵌套:保留HTML中的代码结构

①嵌套默认是后代选择器,如果需要子代选择器,则在子代前加>

②.&表示上一层 &:表示上一层的hover事件

section {
  p {
    color: red;
    background-color: yellowgreen;
    text-align: center;
  }
  ul {
    padding: 0px;
    list-style: none;
    li {
      float: left;
      margin: 10px;
      width: 100px;
      text-align: center;
      border: @border;
      &:hover {
        background-color: yellow;
      }
    }
  }
}

2、Sass:

1、Sass中的变量

使用 $变量名:变量值,声明变量;

如果变量需要在字符串中嵌套,则需使用#加大括号包裹;

border-#{$left}:10px solid blue;

2、Sass中的运算

会将单位也进行运算,使用时需注意最终单位例:10px*10px=100px*px

3、sass中的嵌套:

选择器嵌套,属性嵌套,伪类嵌套

选择器嵌套 :

      ul{ li{} } 后代
           ul{ >li{} } 子代
&:表示上一层 div{ ul{ li{ &=="div ul li" } } }

属性嵌套:

属性名与大括号之间必须有:

例如:border:{color:red;}

伪类嵌套:ul{li{ &:hover{ "ul li:hover" } } }

4、混合宏、继承、占位符

①混合宏:

声明:@mixin name($param:value){}

调用:@include name(value);

>>>声明时,可以有参,可以无参;可带默认值,也可不带;但是,调用时,必须符合声明规范。同less

>>>优点:可以传参,不会生成同名class;

>>>缺点:会将混合宏中的代码,copy到对应的选择器中,产生冗余代码!

②继承:

声明:.class{}

调用:@extend .class;

>>>优点:继承的相同代码,会提取到并集选择器中,减少冗余代码

>>>缺点:无法进行传参,会在css中,生成一个同名class

③占位符:

声明:&class{}

调用:@extend %class;

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

>>>缺点:无法进行传参

综上所述:当需要传递参数时,用混合宏;当有现成的class时用继承;当不需要参数,也不需要class时,用占位符

5、if条件结构:

@if 条件 {}
@else {}

6、for循环结构:

//不包含10;
@for $i from 1 to 10{}
//包含10;
@for $i from 1 through 10{}

7、while循环结构:

$j: 1;
@while $j<10 {
  .while#{$j} {
    border: #{$j}px solid red;
  }
  $j: $j+1;
}

8、each循环遍历

@each item in a,b,c,d{
//item表示每一项
}

9、函数:

@function func($length) {
  $length1: $length*5;
  @return $length1;
}
//调用:
func(10px);

10、使用...将传进来的所有参数,接收到一个变量中

@mixin bordeRadius($param1...) {
  //使用...将传进来的所有参数,接收到一个变量中
  border-radius:$param1;
  -webkit-border-radius:$param1;
}

转自http://www.cnblogs.com/hope666/p/6791790.html

less与sass的区别的更多相关文章

  1. 【less和sass的区别,你了解多少?】

    在介绍less和sass的区别之前,我们先来了解一下他们的定义: 一.Less.Sass/Scss是什么? 1.Less: 是一种动态样式语言. 对CSS赋予了动态语言的特性,如变量.继承.运算.函数 ...

  2. less和sass的区别

    首先sass和less都是css的预编译处理语言,他们引入了mixins,参数,嵌套规则,运算,颜色,名字空间,作用域,JavaScript赋值等 加快了css开发效率,当然这两者都可以配合gulp和 ...

  3. IasS,CasS,PasS,SasS的区别

    IasS: (Infrastructure-as-a-Service(基础设施即服务)) 租用的是硬件,服务器,物理机等 CasS: (container as a Service) 容器服务 租用的 ...

  4. 关于sass的介绍和基本语法

    引入 什么是sass?sass是css预处理器. 那预处理器又是什么?css本身不是一种编程语言,而预处理器是用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件. 如今主流的预处理器 ...

  5. sass 基础——回顾

    1.webstorm 自动编译SASS 下载安装包 http://rubyinstaller.org/downloads/ 然后点击安装,路径为默认路径就行, 勾选以下两项 add Ruby exec ...

  6. Less、Sass/Scss

    一.Less.Sass/Scss是什么? 1.Less: 是一种动态样式语言. 对CSS赋予了动态语言的特性,如变量.继承.运算.函数. Less 既可以在客户端上运行 (支持IE 6+, Webki ...

  7. Bootstrap定制(一)less入门及编译

    第一篇博,希望支持. 近期在开发一个项目,项目前端定位于bootstrap,遂花了少许时间研究了bootstrap,将其整理整理,与众人共享. bootstrap官方的定制,功能还算完善,但是基于we ...

  8. css的扩展技术

    CSS的扩展技术 (在原来的CSS语言的基础上扩展了js,可以在里面写js ) 一.less 定义: @color:red; //定义颜色 @body-color:blue; @div-color:y ...

  9. CSS预处理语言

    CSS预处理语言 Less,Sass,Stylus 安装 Less yarn add less 运行命令 ./node_modules/.bin/lessc 嵌套规则 Less.Sass嵌套规则一样 ...

随机推荐

  1. log4j漏洞的产生原因和解决方案,小白都能看懂!!!!

    核弹级bug Log4j,相信很多人都有所耳闻了,这两天很多读者都在问我关于这个bug的原理等一些问题,今天咱们就专门写一篇文章,一起聊一聊这个核弹级别的bug的产生原理以及怎么防止 产生原因 其实这 ...

  2. Kafka从入门到放弃(三)—— 详说消费者

    之前介绍了Kafka以及生产者,包括它的一些特性和参数,这回写一下消费者. 之前没看得可以点击链接阅读. Kafka从入门到放弃(一) -- 初识Kafka Kafka从入门到放弃(二) -- 详说生 ...

  3. CF805B 3-palindrome 题解

    Content 给定一个整数 \(n\),请构造出长度为 \(n\) 的仅含 a.b.c 三个字母的字符串,使得其中没有长度为 \(3\) 的回文子串,并且 c 出现的次数尽可能少. 数据范围:\(1 ...

  4. LuoguP7398 [COCI2020-2021#5] Šifra 题解

    Content 给定一个长度 \(n\) 的只包含小写字母和 \(0\sim9\) 的字符串(字符串中的字母可视为分隔符).求字符串中包含多少个不同的数字. 数据范围:\(1\leqslant n\l ...

  5. java 多线程:线程安全问题synchronized关键字解决

    背景: 多个线程同时修改一个变量时,有概率导致两次修改其中某些次被覆盖. 例如:如下案例一个变量值为3,三个线程同时对其-1,如果按顺序执行,每次减完的结果应该是2,1,0.但实际运行中有可能变为0, ...

  6. Java面向对象之 接口: [修饰符] interface 接口名 {...};子接口:[修饰符] interface 接口名 extends 父接口,父接口2...{...}

    1.什么是接口? 类比抽象类,把功能或者特性类似的一类 抽象的更彻底,可以提炼出更加特殊的"抽象类"----接口 2.如何定义接口 语法:  [修饰符] interface 接口名 ...

  7. Tornado 异步浅解

    7.1 认识异步 1. 同步 我们用两个函数来模拟两个客户端请求,并依次进行处理: #!/usr/bin/env python3 # -*- coding:utf-8 -*- # @Time: 202 ...

  8. SQL:利用多表更新优化子查询

    原SQL: update bi_data.order_list_wxset is_start='1',proc_time=now()where 1=1and is_end='0' and 交易时间&l ...

  9. 金智维RPA培训(一)产品基础架构-RPA学习天地

    1.产品组成分为:Server,control,agent三个组件,支持CS和BS架构.独有的中继服务器可以解决跨网段的问题,这里应该还是采用了多网卡模式. 其中:Agent负责对流程的执行工作.Co ...

  10. windows串口之虚拟串口和Access port

    关于 本文将介绍自己常用的串口工具,演示环境为Windows. 1. 虚拟串口 1.1 没有那么多的物理串口, 用虚拟串口来凑.需要软件Configure Virtual Serial Port Dr ...