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开发体验,建议从变量和嵌套开始逐步实践高级功能。

相关推荐
向前跑丶加油3 小时前
解决 Element Plus 中 Tooltip 样式影响全局菜单(Menu)及宽度控制失效的完美方案
css·elementui
ZC跨境爬虫3 小时前
UI前端美化技能提升日志day1:矢量图片规范与自适应控制栏实战
前端·css·ui·状态模式
捧月华如3 小时前
HTML/CSS基础:构建网页的骨架与样式
前端·css·html
梓言20 小时前
解决 Element Plus 中 Tooltip 样式影响全局菜单(Menu)及宽度控制失效的完美方案
前端·css·element
小蜜蜂dry20 小时前
css变量
前端·css
青花瓷1 天前
在PyCharm的Django工程中修改初始页
css·html·css3
skywalk81631 天前
CherryStudioWeb:一个优雅的 AI 聚合导航页,让你在一个页面访问所有主流 AI 服务。
前端·css·人工智能·html
Mh2 天前
鼠标跟随倾斜动效
前端·css·vue.js
CyrusCJA2 天前
毛玻璃效果
前端·css·css3