less 和 sass的区别

规则上相同

  • 变量
  • 嵌套规则
  • 导入
  • 混入
  • 运算
  • 注释
  • 函数 写法类似于script、也有一些指令

规则和写法上相同的地方

  1. 变量 变量也都支持块作用域,类属于js的那

    css 复制代码
    @var: red; #page { 
        @var: white; #header { 
            color: @var; // white /**/
        } 
    }
    • less的变量是使用@ ,@width
    • sass是使用 <math xmlns="http://www.w3.org/1998/Math/MathML"> , , </math>,width
    css 复制代码
    @width: 10px; 
    @height: @width + 10px;
    
    #header { 
        width: @width; height: @height;
    }
  2. 嵌套规则(&,嵌套属性)

    css 复制代码
    #header { 
        color: black;
        .navigation {
            font-size: 12px; 
        } 
        .logo { 
            width: 300px; 
        } 
    }
  3. 导入

    • @import 可以是less、scss、css文件的导入
  4. 混入(将一个规则集集合混入到另一个规则集集合中)

    • Less
    css 复制代码
    .bordered { 
        border-top: dotted 1px black;
        border-bottom: solid 2px black; 
    }
    
    #menu a { 
        color: #111; 
        .bordered(); // 混入规则集及
    }
    .post a { 
        color: red; 
        .bordered();
    }
    
    /* 也可以类似于函数的方式使用*/
    .some .selector div { 
        .mixin(#008000); 
    }
    • sass 需要使用@mixin定义,然后在使用@include导入规则集
    css 复制代码
    @mixin rounded-corners {
      -moz-border-radius: 5px;
      -webkit-border-radius: 5px;
      border-radius: 5px;
    }
    notice {
      background-color: green;
      border: 2px solid #00aa00;
      @include rounded-corners;
      /* 也可以类似于函数的方式使用*/
      @include rounded-corners(#000);
    }
  5. 运算

    • less
    css 复制代码
    @conversion-1: 5cm + 10mm; // 结果是 6cm
    • sass
    css 复制代码
    $conversion-1: 5cm + 10mm; // 结果是 6cm 
    color: #222 / 2  /* color : #111*/
  6. 函数(内置很多函数,也可以类似于混入中的函数方法来使用)

    • less (函数)
    css 复制代码
    $conversion-1: 5cm + 10mm; // 结果是 6cm 
    color: #222 / 2  /* color : #111*/
    • sass (SassScript)
    css 复制代码
    $conversion-1: 5cm + 10mm; // 结果是 6cm 
    color: #222 / 2  /* color : #111*/

规则上不相同的

  1. less

    • 转义
    css 复制代码
    @min768: ~"(min-width: 768px)";  /* ~ 是转义标志符号*/
    .element { 
        @media @min768 { 
            font-size: 1.2rem;
        } 
    }
    • 映射 maps
    css 复制代码
    #colors() { 
        primary: blue; 
        secondary: green; 
    } 
    .button { 
        color: #colors[primary]; /* = colors.primary 这样的方式 */
        border: 1px solid #colors[secondary];
    }
  2. sass

    • 继承

    • 内置控制指令

      @if @each @else @while @foreach

区别:

  1. less是支持客户端和服务端使用,而sass是支持服务端运行,目前基本上是都通过构建工具进行预处理之后,直接以css的在客户端展示。
  2. sass算是最早出现的预处理器,有更强大的社区和实践方案、使用案例更多
  3. sass内置的规则也相对比较多
相关推荐
Mike_jia4 分钟前
TCP 粘包/拆包问题
前端
沐墨染11 分钟前
敏感词智能检索前端组件设计:树形组织过滤与多维数据分析
前端·javascript·vue.js·ui·数据挖掘·数据分析
Kagol13 分钟前
🎉TinyPro v1.4.0 正式发布:支持 Spring Boot、移动端适配、新增卡片列表和高级表单页面
前端·typescript·开源
李少兄14 分钟前
B/S 架构:现代 Web 应用的核心架构模式
前端·架构·b/s
鹏程十八少27 分钟前
破解Android悬浮窗遮挡无障碍服务难题:我在可见即可说上踩过的坑
android·前端·面试
Kapaseker31 分钟前
前端已死...了吗
android·前端·javascript
m0_4711996334 分钟前
【自动化】前端开发,如何将 Jenkins 与 Gitee 结合实现自动化的持续集成(构建)和持续部署(发布)
前端·gitee·自动化·jenkins
w***954935 分钟前
spring-boot-starter和spring-boot-starter-web的关联
前端
Moment39 分钟前
富文本编辑器技术选型,到底是 Prosemirror 还是 Tiptap 好 ❓❓❓
前端·javascript·面试
xkxnq44 分钟前
第二阶段:Vue 组件化开发(第 18天)
前端·javascript·vue.js