面试必看:less与sass的区别

less与sass的区别

        在介绍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

    >>>变量使用原则:

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

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事件

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;}


四. 总结

不管是Sass,还是Less,

都可以视为一种基于CSS之上的高级语言,

其目的是使得CSS开发更灵活和更强大,

Sass的功能比Less强大,

基本可以说是一种真正的编程语言了,

Less则相对清晰明了,易于上手,对编译环境要求比较宽松。

考虑到编译Sass要安装Ruby,而Ruby官网在国内访问不了,个人在实际开发中更倾向于选择Less,

但也会去尝试使用sass,毕竟为以后的工作做准备。


五.扩展思考

处理机制不一样会带来什么不同?

因为Less与Sass处理机制不一样,

前者是通过客户端处理的,

后者是通过服务端处理,

相比较之下前者解析js会比后者慢一点。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342