CSS预处理器:Sass/Less入门

Sass/Less简介

CSS预处理器(如Sass、Less)通过引入变量、嵌套、混合等特性,增强CSS的可维护性和开发效率。Sass基于Ruby(后移植到Dart),Less基于JavaScript,两者功能类似但语法略有差异。


安装与配置

Sass

通过npm安装Dart版本的Sass(推荐):

bash 复制代码
npm install -g sass

编译.scss文件:

bash 复制代码
sass input.scss output.css

Less

通过npm安装Less:

bash 复制代码
npm install -g less

编译.less文件:

bash 复制代码
lessc input.less output.css

核心功能对比

变量

Sass (使用$符号):

scss 复制代码
$primary-color: #3498db;
body { color: $primary-color; }

Less (使用@符号):

less 复制代码
@primary-color: #3498db;
body { color: @primary-color; }
嵌套规则

两者语法一致:

scss 复制代码
nav {
  ul { margin: 0; }
  a { color: red; }
}
混合(Mixins)

Sass

scss 复制代码
@mixin border-radius($radius) {
  border-radius: $radius;
}
.box { @include border-radius(10px); }

Less

less 复制代码
.border-radius(@radius) {
  border-radius: @radius;
}
.box { .border-radius(10px); }
继承

Sass (使用@extend):

scss 复制代码
.error { color: red; }
.warning { @extend .error; }

Less(通过混合模拟):

less 复制代码
.error { color: red; }
.warning { .error(); }
运算与函数

两者均支持数学运算和内置函数:

scss 复制代码
$width: 100px;
.container { width: $width * 2; }

高级特性

Sass特有功能

Less特有功能

  • 实时编译(浏览器端支持)
  • 懒加载(变量可后定义)

开发建议

  1. 项目选型:新项目推荐Sass(功能更全面),旧项目可沿用Less。
  2. 工具链:结合构建工具(Webpack、Gulp)实现自动化编译。
  3. 调试:使用Source Map映射原始文件。

通过预处理器可显著提升CSS开发体验,建议从变量和嵌套开始逐步实践高级功能。

相关推荐
llllk4 小时前
新手向逐段讲解
css
玄玄子2 天前
CSS 浮动引起父元素高度塌陷
前端·css
用户0926292831452 天前
CSS 代码调试总踩坑?Gemini 3.5 精准定位修复
css
zzzzzz3104 天前
当甲方说'logo放大的同时再缩小一点'时,我用 AI 把这个需求做出来了
javascript·css·程序员
闪闪发光得欧4 天前
前端提效新思路:Gemini 3.5 自动化定位 CSS 异常
前端·css
用户059540174468 天前
AI Agent记忆测试踩坑实录:Mock骗了我一周,Mem0+pytest一招破局
前端·css
Darling噜啦啦8 天前
CSS 3D 变换与 Flex 布局实战:从零打造旋转立方体
前端·css
用户059540174469 天前
把待办应用从Electron换成Tauri,内存占用狂降90%,打包体积仅5MB
前端·css
小月土星9 天前
CSS 3D 从入门到炫技:手把手教你写一个旋转立方体
前端·css
xingpanvip9 天前
星盘接口开发文档:本命盘接口指南
android·开发语言·css·php·lua