sass、scss、less、的区别

sass、scss、less都是css预处理器,区别如下:

1语法格式:

sass采用缩进格式,不使用大括号和分号

css 复制代码
$color: #333
body
 background-color: $color;
 font-size: 14px;
 h1:
    color: $color

scss与css语法相似,使用大括号和分号

css 复制代码
$color: #333;

body {
  background-color: $color;
  font-size: 14px;
  h1 {
    color: $color;
  }
}

less同样类似css语法

css 复制代码
@color: #333;

body {
  background-color: @color;
  font-size: 14px;
  h1 {
    color: @color;
  }
}

2变量定义与使用:

sass和scss都使用$符定义变量

css 复制代码
$primary-color: #007bff;
$secondary-color: #6c757d;

.button {
  background-color: $primary-color;
  color: $secondary-color;
}

less使用@符号定义变量

css 复制代码
@primary-color: #007bff;
@secondary-color: #6c757d;

.button {
  background-color: @primary-color;
  color: @secondary-color;
}

3嵌套规则:

sass和scss都使用$符表示父元素

css 复制代码
nav {
  ul {
    list-style: none;
    li {
      display: inline-block;
      a {
        color: #333;
        &:hover {
          color: #000;
        }
      }
    }
  }
}

less使用~表示父元素

css 复制代码
nav {
  ul {
    list-style: none;
    li {
      display: inline-block;
      a {
        color: #333;
        &:hover {
          color: #000;
        }
      }
    }
  }
}

4混合(Mixins):

sass和scss通过@mixin定义,@include调用

css 复制代码
@mixin button-style {
  background-color: #007bff;
  color: #fff;
  padding: 10px 20px;
  border-radius: 5px;
}

.button {
  @include button-style;
}

less使用.mixin()形式定义和调用

css 复制代码
.button-style() {
  background-color: #007bff;
  color: #fff;
  padding: 10px 20px;
  border-radius: 5px;
}

.button {
 .button-style();
}

5继承:

sass、scss和less都使用@extend实现继承

css 复制代码
//sass
.error {
  border: 1px solid red;
  background-color: #f8d7da;
}

.serious-error {
  @extend.error;
  border-width: 3px;
}


//less

.error {
  border: 1px solid red;
  background-color: #f8d7da;
}

.serious-error {
  @extend.error;
  border-width: 3px;
}
相关推荐
会跑的葫芦怪13 天前
SaaS点餐平台难点详细解决方案
spring boot·sass
豆豆13 天前
如何通过PageAdmin完成网站上线并设置SEO关键词
cms·网站建设·网站制作·sass·建站系统·建站平台·自助建站
AI_567815 天前
Sass代码优化:混合宏+占位符提升CSS可维护性
人工智能·sass
feasibility.20 天前
打造AI+准SaaS:中文法律检索分析平台
vue.js·人工智能·自然语言处理·django·sass·web·法律
豆豆21 天前
CMS:从零开始构建内容管理系统
cms·sass·建站系统·建站平台·自助建站·内容管理系统·网站管理系统
EHagSJVNpTY1 个月前
基于樽海鞘算法(SSA)的极限学习机(ELM)回归预测对比:BP、GRNN、ELM与SSA - ELM
scss
局外人LZ1 个月前
Uniapp脚手架项目搭建,uniapp+vue3+uView pro+vite+pinia+sass
前端·uni-app·sass
腾讯蓝鲸智云1 个月前
【运维自动化-节点管理】节点管理跟配置平台的联动关系
运维·服务器·经验分享·自动化·sass·paas
方也_arkling1 个月前
Element Plus主题色定制
javascript·sass
@AfeiyuO1 个月前
Vue 引入全局样式scss
前端·vue·scss