Sass与Less的特性与区别

前言

Sass和Less简介

Sass

Sass是一种CSS预处理器,它使用一个更加强大的语法来编写CSS。Sass允许使用变量、嵌套、混合(mixins)、继承等功能,从而提高代码的可重用性和可维护性。

Less

Less也是一种CSS预处理器,它同样提供了变量、混合、函数等特性。Less的语法相对简单,易于上手,它可以在服务器端编译。

Sass与Less对比

变量

Sass

css 复制代码
$primary-color: #42b983;

.button {
  background: $primary-color;
}

Less

less 复制代码
@primary-color: #42b983;

.button {
  background: @primary-color;
}

嵌套

Sass

css 复制代码
.nav {
  ul {
    li {
      a {
        color: blue;
      }
    }
  }
}

Less

与Sass相同

Mixin(混入)

Sass

css 复制代码
@mixin flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.box {
  @include flex-center;
}

Less

css 复制代码
.flex-center() {
  display: flex;
  justify-content: center;
  align-items: center;
}

.box {
  .flex-center();
}

继承(Extend)

Sass

css 复制代码
%base {
  border: 1px solid #ccc;
  padding: 10px;
}
.card {
  @extend %base;
}

Less

css 复制代码
.base {
  border: 1px solid #ccc;
  padding: 10px;
}

.card {
  &:extend(.base);
}

运算

Sass

arduino 复制代码
.container {
  width: 600px + 200px; // 800px
}

Less

arduino 复制代码
.container {
  width: (600px + 200px); // 800px
}

条件语句

Sass

less 复制代码
$theme: light;

@if $theme == light {
  body { background: white; }
} @else {
  body { background: black; }
}

Less

less 复制代码
@theme: light;

body when (@theme = light) {
  background: white;
}
body when (@theme = dark) {
  background: black;
}

循环

Sass

less 复制代码
@for $i from 1 through 3 {
  .m-#{$i} {
    margin: $i * 10px;
  }
}

编译后:

css 复制代码
m-1 { 
	margin: 10px; 
} 
.m-2 { 
	margin: 20px; 
} 
.m-3 { 
	margin: 30px; 
}

Less

less 复制代码
.loop(@i) when (@i <= 3) {
  .m-@{i} {
    margin: (@i * 10px);
  }
  .loop(@i + 1);
}
.loop(1);

编译结果一样,但 Less需要递归写法。 编译后:

css 复制代码
m-1 { 
	margin: 10px; 
} 
.m-2 { 
	margin: 20px; 
} 
.m-3 { 
	margin: 30px; 
}

模块化与导入

Sass模块化

less 复制代码
// math 模块
@use "sass:math";

.container {
  width: math.div(600px, 960px) * 100%;
}

Less导入

Less 只有 @import,没有 Sass 的模块系统

css 复制代码
@import "variables.less";

.container {
  width: (600px / 960px * 100%);
}
相关推荐
我的xiaodoujiao1 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 25--数据驱动--参数化处理 Excel 文件 2
前端·python·学习·测试工具·ui·pytest
岁月宁静28 分钟前
从0到1:智能汇 AI 全栈实战,拆解多模态 AI 应用开发全流程
前端·vue.js·node.js
廾匸64029 分钟前
语义化标签
前端·javascript·html
烛阴1 小时前
隐式vs显式:解密C#类型转换的底层逻辑
前端·c#
Fantasydg1 小时前
AJAX JSON学习
前端·学习·ajax
瓢儿菜20181 小时前
Web开发:什么是 HTTP 状态码?
前端·网络协议·http
1024小神2 小时前
swiftui使用WKWebView加载自签的https服务,允许不安全访问
前端
anyup2 小时前
支持鸿蒙!开源三个月,uView Pro 开源库近期更新全面大盘点,及未来计划
前端·vue.js·uni-app
BBB努力学习程序设计2 小时前
用Bootstrap一天搞定响应式网站:前端小白的救命稻草
前端·html
嘴平伊之豬2 小时前
跟着AI速度cli源码三-交互问答系统
前端·node.js