dart-sass与node-sass的区别以及使用dart-sass可能会出现的问题

🐱 个人主页:不叫猫先生
🙋‍♂️ 作者简介:前端领域新星创作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀!
💫系列专栏:vue3从入门到精通TypeScript从入门到实践
📢 资料领取:前端进阶资料以及文中源码可以找我免费领取
🔥 前端学习交流:博主建立了一个前端交流群,汇集了各路大神,互相交流学习,期待你的加入!(文末有我wx或者直接私信)

前言

2020年10月27日,Sass 官方团队正式宣布 Libsass 将弃用,以及基于它的 Node Sass 和 SassC,并且建议用户使用 Dart Sass。如果在vue脚手架搭建的项目中需要使用sass,建议初始化时勾选sass配置,自行安装,选择默认的就是dart-sass。dart-sass替代node-sass根本原因:node-sass无法下载特定版本的二进制依赖文件(博主没有深入研究)

dart-sass使用前需要注意几点:

  • dart-sass 和 node-sass都是用来将sass编译成css的工具,所以都依赖sass-loader。但node-sass 与 node.js 版本相关联,这就导致,一旦本地 node.js 升级,就会出现 node-sass 无法工作的情况
  • npm 上的 dart-sass 包已被弃用,直接更名为 sass
  • dart-sass 不支持/deep/,要改成::v-deep

安装dart-sass

卸载node-sass

yarn remove node-sass

安装dart-sass

yarn add sass -D

dart-sass与node-sass 的区别:

  • node-sass 是用 node(调用 cpp 编写的 libsass)来编译 sass
  • dart-sass 是用 drat VM 来编译 sass
  • node-sass是自动编译实时的,dart-sass需要保存后才会生效
  • dart-sass 性能更好(也是 sass 官方使用的),而且 node-sass依赖node版本,所以会出很多问题(node-sass:4.14.1,node:14.19.3可以正常使用,mac本node-sass依赖python3,装机默认是python2.7,所以还需要下载python3)

dart-sass优势

  • 不存在依赖二进制文件即可完成安装,避免了node-sass因为依赖其他文件而失败
  • 允许使用sass和css新特性
  • 避免工程其他依赖升级的不兼容node-sass导致报错的问题

dart-sass缺陷

  • 性能:由于node-sass使用C++实现的样式预处理器,速度相比于纯Javascript实现Dart Sass要快
  • 内存:执行编译过程中,Node Sass的内存占用也比Dart Sass要小很多

常出问题

1. Using / for division outside of calc() is deprecated and will be removed in Dart Sass 2.0.0.

问题截图如下:

在这里插入图片描述

主要是在写css中使用/出的错

css语法里面已经添加了/作为分隔符的使用。sass作为css的超集,也会跟进这个改动,所以sass2.0的时候 /就会被弃用。
但是在calc函数里面仍然是有效的,也就是说,我们以后用除法的时候,直接在calc函数里使用,或者除2的时候改成*0.5就没有问题了。本来css就是只在calc支持除法,所以问题不大。
官方给出的解决办法是math.div()方法,当然官方不会让你一个一个修改,给出了批量修改工具。

安装sass-migrator

yarn add -g sass-migrator

批量修改

sass-migrator division **/*.scss

编译之前

margin-right: #{$--tooltip-arrow-size/0.55};

编译之后

margin-right: #{math.div($--tooltip-arrow-size, 0.55)};

2.SassError: expected selector. /deep/

问题截图如下:在这里插入图片描述

在写css中使用/deep/出的错,将/deep/替换成::v-deep即可。

3.SassError: expected identifier

问题截图如下:

在这里插入图片描述
错误原因应该是不能直接使用小数,transition:all (1.6*0.5)s,有遇到该问题的兄弟可留言,博主目前这么解决的

  1. vue项目中使用的element ui的icon乱码,需要在vue.config.js中加入以下代码
module.exports = {
  css: {
    loaderOptions: {
      sass: {
        implementation: require('sass'),
        sassOptions: {
          // 生效代码
          outputStyle: 'expanded'
        }
      }
    }
  }
 }
  • 11
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
### 回答1: Dart-sassnode-sass都是用于编译Sass代码的工具。Dart-sass是由Dart语言编写的,而node-sass是由Node.js编写的。它们都可以将Sass代码编译成CSS代码,并提供了许多功能,如变量、嵌套、混合等。Dart-sass相对于node-sass来说,速度更快,但是需要安装Dart环境。而node-sass则可以直接在Node.js环境下使用。 ### 回答2: Dart-SassNode-Sass是两种常用的Sass编译器。 Dart-Sass是一款基于Dart语言开发的Sass编译器,由Sass核心开发者Hampton Catlin和其他贡献者共同开发和维护。Dart-Sass是官方推荐的Sass编译器,支持最新的Sass语法和功能,如@forward、CSS模块以及其他的一些更新。 Node-Sass是一款基于Node.js平台开发的Sass编译器,由Hugo Giraudel和Andrew Nesbitt共同开发和维护。Node-Sass是最早出现Sass编译器之一,得到了广泛的使用和认可。它支持较早版本的Sass语法和功能,并且能够提供更好的性能让开发者可以更快地编译Sass文件。 两款编译器的主要区别在于他们的运行平台,Dart-Sass运行于Dart平台上,而Node-Sass运行于Node.js平台上。此外,Dart-Sass更加符合最新的Sass语法规范,更能提供更好的性能和处理能力,因此已被官方推荐为首选的Sass编译器。而Node-Sass则更注重与Node.js的兼容性和能够兼容更早的Sass语法版本。 总的来说,选择哪一款Sass编译器应该根据项目需要和开发者的喜好而定。如果注重使用最新的Sass语法和功能,以及更好的性能,可以选择Dart-Sass。而如果需要通用性更强的编译器,并且更能兼容早期的Sass语法版本,可以选择Node-Sass。 ### 回答3: Dart-sassnode-sass都是Sass编译器,它们可以将Sass或者Scss代码编译成CSS代码。Sass是一种CSS预处理器,它使用类似于编程语言的语法来定义CSS样式,让CSS的编写更加快捷、直观。而Dart-sassnode-sass则是Sass语言的解析器,在编译Sass代码时可以实现一些高级功能,如使用变量、函数、嵌套等。 Dart-sass使用Dart语言进行编写,其最明显的特点是速度快,比node-sass快得多,且支持最新的Sass语法特性。另外,Dart-sass的错误信息也更加明显和容易理解。但是,Dart-sass的代码数量比较多,对于初学者来说可能有一点陌生。 node-sass是一款基于Node.js的Sass编译器,它是由C++实现的,性能也非常好。在安装和使用上比较简单,不需要学习新的语言的语法。但是,相比Dart-sassnode-sass对于Sass 3.5语法的支持不太好,而且在错误提示方面可能不如Dart-sass。 对于哪种Sass编译器更好,在很大程度上取决于个人情况和需求。如果对于速度要求比较高,或者需要使用新的Sass语法特性,那么Dart-sass比较适合。如果希望使用方便、错误提示较为清晰,且不需要使用最新的Sass语法特性,那么node-sass可能比较适合。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不叫猫先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值