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

相关推荐
gCode Teacher 格码致知6 小时前
Javascrip提高:CSS backdrop-filter的使用方法-由Deepseek产生
前端·css
gCode Teacher 格码致知6 小时前
Javascript提高:canvas画布的网格背景-由Deepseek产生
javascript·css·css3
gCode Teacher 格码致知6 小时前
Javascript提高:使用canvas绘制一个绚丽的按钮-由Deepseek产生
javascript·css·css3
他是龙5518 小时前
SQLi-Labs 通关笔记(Less-38 ~ Less-53):堆叠注入与 ORDER BY 注入
数据库·笔记·less
yanyu-yaya9 小时前
css篇之网格grid 学习
前端·css·学习
@大迁世界21 小时前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
梨子同志1 天前
CSS Grid
前端·css
YOU OU1 天前
HTML+CSS+JavaScript
前端·javascript·css·html
小彭努力中1 天前
205.Vue3 + OpenLayers:加载动画,采用 CSS 的 @keyframes 方式
前端·css·vue.js·openlayers·cesium·webgis
腾讯蓝鲸智云2 天前
【运维自动化-节点管理】节点管理的插件策略如何使用
运维·自动化·云计算·sass·paas