Tiven

Tiven

博观而约取,厚积而薄发

天问的个人网站(天问博客),专注于Node.js、Vue.js、React、Vite、Npm、Nginx等大前端技术。不断学习新技术,记录日常开发问题,持续分享coding,极客开源,共同进步。生命不息,奋斗不止... [ Hexo Blog ]

Stylelint: Expected list.nth instead of nth (scss/no-global-function-names)


vue3 + vite 项目中,使用 Stylelint 检查和格式化 css、less、scss 代码格式,遇到这个报错:Stylelint: Expected list.nth instead of nth (scss/no-global-function-names)

Sass & Stylelint

代码展示

$colors: #66b1ff, #84ce62, #ebb563, #f78a89, #b799ff, #f99b7d, #afdafe, #b7e7e1, #efedd4;

@for $i from 1 through length($colors) {
  .annotator-hl-#{$i} {
    background: nth($colors, $i);
    cursor: pointer;
  }
}

问题原因

在这个 @for 循环中使用了 sass 内置的 nth 函数,被 Stylelint 工具检查报错。

解决办法

有两种方法能使 Stylelint 不标红报错。

  1. .stylelintrc 配置文件中配置忽略规则
module.exports = {
  rules: {
    'scss/no-global-function-names': null // 添加这一行
  }
}
  1. 在自己的 scss 文件中加载使用 list 模块,以 list.nth 的形式使用 nth 函数。(推荐)
@use "sass:list"; /* 重点 */

$colors: #66b1ff, #84ce62, #ebb563, #f78a89, #b799ff, #f99b7d, #afdafe, #b7e7e1, #efedd4;

@for $i from 1 through length($colors) {
  .annotator-hl-#{$i} {
    background: list.nth($colors, $i); /* 重点 */
    cursor: pointer;
  }
}
  • 参考文档:https://github.com/stylelint-scss/stylelint-scss/blob/master/src/rules/no-global-function-names/README.md

欢迎访问:天问博客