# narcissus-fe-lint

narcissus-fe-lint纳西索斯 前端编码规范工程化 (opens new window)的配套 Lint 工具,可以为项目一键接入规范、一键扫描和修复规范问题,保障项目的编码规范和代码质量。

# 背景

我们引入了多个业界流行的 Linter,并根据规范内容定制了规则包,它们包括:

规范 Lint 工具 npm 包
JavaScript 编码规范
TypeScript 编码规范
Node 编码规范
ESLint (opens new window) narcissus-fe-eslint-config (opens new window)
CSS 编码规范 stylelint (opens new window) narcissus-fe-stylelint-config (opens new window)
Git 规范 commitlint (opens new window) narcissus-fe-commitlint-config (opens new window)
文档规范 markdownlint (opens new window) narcissus-fe-markdownlint-config (opens new window)

可以看到这些 Linter 和规则包众多且零散,全部安装它们会给项目增加十几个依赖,接入和升级成本都比较高。

narcissus-fe-lint 收敛屏蔽了这些依赖和配置细节,提供简单的 CLI 和 Node.js API,让项目能够一键接入、一键扫描、一键修复、一键升级,并为项目配置 git commit 卡口,降低项目接入规范的成本。

# CLI 使用

# 安装

在终端执行:

npm install narcissus-fe-lint -g

安装完成后,可执行 narcissus-fe-lint -h 以验证安装成功。

# 使用

# narcissus-fe-lint init:一键接入

在项目根目录执行 narcissus-fe-lint init,即可一键接入规范,为项目安装规范 Lint 所需的依赖和配置。

具体会做以下事情:

注 1:如果项目已经配置过 ESLint、stylelint 等 Linter,执行 narcissus-fe-lint init 将会提示存在冲突的依赖和配置,并在得到确认后进行覆盖:

注 2:如果项目的 .vscode/ 目录被 .gitignore 忽略,可以在拉取项目后单独执行 narcissus-fe-lint init --vscode 命令写入 .vscode/extensions.json.vscode/settings.json 配置文件

# Node.js API 使用

# 安装

npm install narcissus-fe-lint --save

# API

# init:初始化

  • narcissus-fe-lint.init(config):将项目一键接入规范,效果等同于 narcissus-fe-lint init

示例:

(await narcissus) -
  fe -
  lint.init({
    eslintType: 'react',
    enableESLint: true,
    enableStylelint: true,
    enableMarkdownlint: true,
    enablePrettier: true,
    disableNpmInstall: false,
  });

config 参数如下:

参数 类型 默认值 说明
cwd string - 项目绝对路径
eslintType ESLintType - 语言和框架类型,如果不配置,等同于 narcissus-fe-lint init,控制台会出现选择器,如果配置,控制台就不会出现选择器
enableESLint boolean true 是否启用 ESLint,如果不配置默认值为 true,即默认启用 ESLint
enableStylelint boolean - 是否启用 stylelint,如果不配置,等同于 narcissus-fe-lint init,控制台会出现选择器,如果配置,控制台就不会出现选择器
enableMarkdownlint boolean - 是否启用 markdownlint,如果不配置,等同于 narcissus-fe-lint init,控制台会出现选择器,如果配置,控制台就不会出现选择器
enablePrettier boolean - 是否启用 Prettier
disableNpmInstall boolean false 是否禁用自动在初始化完成后安装依赖
# ESLintType
  • default: JavaScript 项目(未使用 React 和 Vue 的 JS 项目)
  • react: JavaScript + React 项目
  • vue: JavaScript + Vue 项目
  • typescript/default: TypeScript 项目(未使用 React 和 Vue 的 TS 项目)
  • typescript/react: TypeScript + React 项目
  • typescript/vue: TypeScript + Vue 项目
  • es5: ES5 及之前版本的 JavaScript 老项目

# 配置

narcissus-fe-lint 基于一份配置进行扫描(但你也可以零配置使用),支持的配置参数有:

参数 类型 默认值 说明
enableESLint boolean true 是否启用 ESLint
enableStylelint boolean true 是否启用 stylelint
enableMarkdownlint boolean true 是否启用 markdownlint
enablePrettier boolean - 是否启用 Prettier
eslintOptions ESLint.Options - ESLint 配置项,若未设置将使用执行目录下或内置的默认 eslintrc 和 eslintignore 进行扫描
stylelintOptions stylelint.LinterOptions - stylelint 配置项,若未设置将使用执行目录下或内置的默认 stylelintrc 和 stylelintignore 进行扫描
markdownlintOptions markdownlint.Options - markdownlint 配置项,若未设置将使用执行目录下或内置的默认 markdownlint 配置文件进行扫描

narcissus-fe-lint 会读取执行目录下的 narcissus-fe-lint.config.js 作为配置文件。narcissus-fe-lint init 会在执行目录下新增如下的 narcissus-fe-lint.config.js 文件:

module.exports = {
  enableESLint: true,
  enableStylelint: true,
  enableMarkdownlint: true,
  enablePrettier: true,
};

## 常见问题

### TypeScript 项目扫描性能问题

如果你的 TS 项目 commit 卡口和 `narcissus-fe-lint scan` 运行时间很长,可以通过如下在 `.eslintrc.js` 中增加以下配置提升性能:

```js
module.exports = {
  parserOptions: {
    project: [], // for lint performance
    createDefaultProgram: false, // for lint performance
  },
  rules: {
    '@typescript-eslint/dot-notation': 0, // for lint performance
    '@typescript-eslint/restrict-plus-operands': 0, // for lint performance
  },
};