CSS、SCSS、LESS语法的区别详解

目录

CSS、SCSS、LESS语法的区别详解

1. CSS

2. SCSS

变量

嵌套规则

混合

函数

3. LESS

变量

嵌套规则

混合

函数

区别对比

总结


CSS、SCSS、LESS语法的区别详解

1. CSS

CSS(Cascading Style Sheets)是一种样式表语言,用于描述HTML或XML(包括如SVG、XUL等等)文档的外观和格式。CSS描述了如何将元素显示在屏幕上,打印出来,或者以其他方式呈现给用户。
 

css
body {
    background-color: #f0f0f0;
}

h1 {
    color: #333;
    font-size: 2em;
}

CSS没有变量、嵌套规则、混合、函数等高级功能。

2. SCSS

SCSS(Sassy CSS)是CSS预处理器Sass的一种语法格式。它使用全新的语法结构,相比于原生的CSS,SCSS可以使用变量、嵌套规则、混合、函数等高级功能。

变量

在SCSS中,我们可以使用$符号来定义一个变量:
 

scss
$font-stack:    Helvetica, sans-serif;
$primary-color: #333;

body {
  font: 100% $font-stack;
  color: $primary-color;
}


 

嵌套规则

SCSS支持嵌套规则,这意味着你可以在一个选择器内部定义另一个选择器:

scss
nav {
  ul {
    margin: 0;
    padding: 0;
    list-style: none;
  }

  li { display: inline-block; }

  a {
    display: block;
    padding: 6px 12px;
    text-decoration: none;
  }
}

混合

混合是一种可以重复使用的代码块,你可以在任何地方引用它:

scss
@mixin border-radius($radius) {
  -webkit-border-radius: $radius;
     -moz-border-radius: $radius;
      -ms-border-radius: $radius;
          border-radius: $radius;
}

.box { @include border-radius(10px); }

函数

SCSS还支持自定义函数:

scss
@function double($n) {
  @return $n * 2;
}

.box { width: double(5px); }

3. LESS

LESS是一种动态样式语言,也是一种CSS预处理器,它扩展了CSS的语法,增加了变量、混合、函数和许多其他的特性,使得CSS更易维护、主题化和可扩展。

变量

在LESS中,我们可以使用@符号来定义一个变量:

less
@base: #f938ab;

.box { 
  color: saturate(@base, 5%);
  border-color: lighten(@base, 30%);
}

 

嵌套规则

LESS也支持嵌套规则:

less
nav {
  ul {
    margin: 0;
    padding: 0;
    list-style: none;
  }

  li { display: inline-block; }

  a {
    display: block;
    padding: 6px 12px;
    text-decoration: none;
  }
}

混合

混合在LESS中的使用方法和SCSS类似:

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

.box { .border-radius(10px); }

函数

LESS也支持自定义函数,但是它们被称为"懒惰求值",因为它们只有在被调用时才会计算:

less
@lazy-eval: 3;
.lazy-eval(@a: @lazy-eval) {
  width: (@a * 2);
}

.lazy-loaded {
  .lazy-eval();
}

区别对比

特性CSSSCSSLESS
变量不支持$var: value;@var: value;
嵌套规则不支持支持支持
混合不支持@mixin name{}; @include name;.name{}; .name();
函数不支持@function name{}; name();支持(懒惰求值)

总结

总的来说,CSS、SCSS和LESS各有各的优点。CSS简单易学,适合小型项目和初学者;SCSS和LESS功能强大,适合大型项目和需要高度定制的场景。在实际开发中,我们可以根据项目的需求和个人的喜好,选择最适合自己的样式表语言。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
LESS和SCSS都是一种基于CSS之上的高级语言,它们都提供了更多的功能和特性,可以大大提高代码编写的效率。LESS语法相对来说更加清晰明了,容易上手。而SCSS在功能上更加强大,支持条件语句等高级特性。 LESS语法示例: 1. 变量声明:使用@符号来声明变量,例如:@color: #333; 2. 混合器:使用.mixin来定义和使用代码块的片段,可以实现代码的复用,例如:.mixin { font-size: 14px; color: #333; } 3. 嵌套规则:可以在父选择器内嵌套子选择器,简化了选择器的书写,例如:.parent { .child { color: red; } } 4. 运算:可以对数值进行加减乘除等运算,例如:@width: 100px + 50px; 5. 导入文件:可以使用@import语句导入其他LESS文件,例如:@import "variables.less"; SCSS语法示例: 1. 变量声明:使用$符号来声明变量,例如:$color: #333; 2. 混合器:使用@mixin来定义和使用代码块的片段,可以实现代码的复用,例如:@mixin mixin { font-size: 14px; color: #333; } 3. 嵌套规则:可以在父选择器内嵌套子选择器,简化了选择器的书写,例如:.parent { .child { color: red; } } 4. 运算:可以对数值进行加减乘除等运算,例如:$width: 100px + 50px; 5. 导入文件:可以使用@import语句导入其他SCSS文件,例如:@import "variables.scss"; 总结来说,LESS和SCSS语法上有一些细微的差异,但整体上非常相似,都提供了类似的功能和特性,具体使用哪一种语法主要取决于个人喜好和项目需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [less和scss区别](https://blog.csdn.net/Jadon_z/article/details/126750935)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [LESS 和 SCSS区别](https://blog.csdn.net/sky89299/article/details/124484021)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三维giser

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值