Skip to main content

命令行接口 (CLI)

¥Command Line Interface (CLI)

你可以在命令行上使用 Stylelint。例如:

¥You can use Stylelint on the command line. For example:

npx stylelint "**/*.css"

你应该在文件 glob 周围添加引号。

¥You should include quotation marks around file globs.

如果你使用 npm 脚本,则需要转义引号:

¥If you are using npm scripts, you'll need to escape the quotes:

{
"scripts": {
"lint": "stylelint \"**/*.css\""
}
}

使用 npx stylelint --help 打印 CLI 文档。

¥Use npx stylelint --help to print the CLI documentation.

选项

¥Options

CLI 接受:

¥The CLI accepts:

--allow-empty-input, --aei

当 glob 模式不匹配任何文件时,进程退出而不抛出错误。更多信息

¥The process exits without throwing an error when glob pattern matches no files. More info.

--cache-location

缓存位置的文件或目录的路径。更多信息

¥Path to a file or directory for the cache location. More info.

--cache-strategy

用于检测已更改文件的缓存策略。可以是 "metadata" 或 "content"。更多信息

¥Strategy for the cache to use for detecting changed files. Can be either "metadata" or "content". More info.

--cache

存储处理文件的结果,以便 Stylelint 只对更改的文件进行操作。默认情况下,缓存存储在 process.cwd() 中的 ./.stylelintcache 中。更多信息

¥Store the results of processed files so that Stylelint only operates on the changed ones. By default, the cache is stored in ./.stylelintcache in process.cwd(). More info.

--color, --no-color

强制启用/禁用颜色。

¥Force enabling/disabling of color.

--config-basedir

定义 "extends"、"插件" 和 "customSyntax" 的相对路径相对于的目录的绝对路径。仅当这些值是相对路径时才需要。更多信息

¥Absolute path to the directory that relative paths defining "extends", "plugins", and "customSyntax" are relative to. Only necessary if these values are relative paths. More info.

--config, -c

包含 配置对象.json、YAML 或 JS 文件的路径。更多信息

¥Path to a JSON, YAML, or JS file that contains your configuration object. More info.

--custom-syntax

指定要在代码上使用的自定义语法。更多信息

¥Specify a custom syntax to use on your code. More info.

--disable-default-ignores, --di

禁用默认忽略。Stylelint 不会自动忽略 node_modules 的内容。更多信息

¥Disable the default ignores. Stylelint will not automatically ignore the contents of node_modules. More info.

--fix

如果可能,自动修复规则报告的问题。更多信息

¥Automatically fix, where possible, problems reported by rules. More info.

--formatter, -f | --custom-formatter

指定格式化程序来格式化结果。更多信息

¥Specify the formatter to format your results. More info.

--globbyOptions, --go

JSON 格式的选项传递给 globby更多信息

¥Options in JSON format passed to globby. More info.

--ignore-disables, --id

忽略 stylelint-disable(例如 /* stylelint-disable block-no-empty */)注释。更多信息

¥Ignore stylelint-disable (e.g. /* stylelint-disable block-no-empty */) comments. More info.

--ignore-path, -i

包含描述要忽略的文件的模式的文件的路径。该路径可以是绝对路径,也可以是相对于 process.cwd() 的路径。你可以重复该选项以提供多个路径。默认情况下,Stylelint 在 process.cwd() 中查找 .stylelintignore更多信息

¥Path to a file containing patterns that describe files to ignore. The path can be absolute or relative to process.cwd(). You can repeat the option to provide multiple paths. By default, Stylelint looks for .stylelintignore in process.cwd(). More info.

--ignore-pattern, --ip

要忽略的文件模式(除了 .stylelintignore 中的文件之外)。

¥Pattern of files to ignore (in addition to those in .stylelintignore).

--max-warnings, --mw

设置接受警告的数量限制。更多信息

¥Set a limit to the number of warnings accepted. More info.

--output-file, -o

写入报告的文件路径。除了 process.stderr,Stylelint 还将报告输出到指定的 filename

¥Path of file to write a report. Stylelint outputs the report to the specified filename in addition to process.stderr.

--print-config

打印给定输入路径的配置。不支持 Glob。

¥Print the configuration for the given input path. Globs are unsupported.

--quiet, -q

仅注册严重性为 "error" 级的规则的问题(忽略 "warning" 级)。更多信息

¥Only register problems for rules with an "error"-level severity (ignore "warning"-level). More info.

--quiet-deprecation-warnings

忽略弃用警告。更多信息

¥Ignore deprecation warnings. More info.

--report-descriptionless-disables, --rdd

生成一份不带描述的 stylelint-disable 注释报告。更多信息

¥Produce a report of the stylelint-disable comments without a description. More info.

--report-invalid-scope-disables, --risd

生成用于配置对象中不存在的规则的 stylelint-disable 注释的报告。更多信息

¥Produce a report of the stylelint-disable comments that used for rules that don't exist within the configuration object. More info.

--report-needless-disables, --rd

生成一份报告来清理你的代码库,仅保留有用的 stylelint-disable 注释。更多信息

¥Produce a report to clean up your codebase, keeping only the stylelint-disable comments that serve a purpose. More info.

--report-unscoped-disables, --rud

生成未限定一个或多个规则范围的配置注释报告。更多信息

¥Produce a report of the configuration comments that are not scoped to one or more rules. More info.

--stdin-filename

用于分配输入的文件名。更多信息

¥A filename to assign the input. More info.

--stdin

接受标准输入,即使它是空的。

¥Accept stdin input even if it is empty.

--validate, --no-validate

强制启用/禁用规则选项的验证。更多信息

¥Force enable/disable the validation of the rules' options. More info.

--version, -v

显示当前安装的 Stylelint 版本。

¥Show the currently installed version of Stylelint.

配置文件规则性能

¥Profile Rule Performance

TIMING 环境变量允许你分析各个规则的性能。

¥The TIMING environment variable allows you to profile the performance of individual rules.

TIMING 设置为 all 或正整数 (n >= 1) 时,它会在 linting 完成时显示运行时间最长的规则的执行时间。这包括规则创建和执行时间,以及每个规则占总规则处理时间的百分比的相对影响。

¥When TIMING is set to all or a positive integer (n >= 1), it displays the execution time of the longest-running rules upon linting completion. This includes both rule creation and execution time, as well as each rule's relative impact as a percentage of the total rule processing time.

$ TIMING=10 npx stylelint "**/*.css"
╔════╤════════════════════════════════════════════════════╤═══════════╤══════════╗
║ # │ Rule │ Time (ms) │ Relative ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 1 │ no-descending-specificity │ 1.154 │ 19.3% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 2 │ no-duplicate-selectors │ 0.357 │ 6.0% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 3 │ length-zero-no-unit │ 0.300 │ 5.0% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 4 │ selector-type-no-unknown │ 0.265 │ 4.4% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 5 │ alpha-value-notation │ 0.251 │ 4.2% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 6 │ declaration-block-no-redundant-longhand-properties │ 0.217 │ 3.6% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 7 │ selector-class-pattern │ 0.187 │ 3.1% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 8 │ value-keyword-case │ 0.151 │ 2.5% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 9 │ declaration-block-no-duplicate-custom-properties │ 0.146 │ 2.4% ║
╟────┼────────────────────────────────────────────────────┼───────────┼──────────╢
║ 10 │ declaration-empty-line-before │ 0.140 │ 2.3% ║
╚════╧════════════════════════════════════════════════════╧═══════════╧══════════╝

你可以通过为 TIMING 设置不同的值来调整结果数量。

¥You can adjust the number of results by setting a different value for TIMING.

例如:

¥For example:

  • TIMING=30 将显示前 30 条规则。

    ¥TIMING=30 will show the top 30 rules.

  • TIMING=all 将显示所有规则。

    ¥TIMING=all will display all rules.

使用示例

¥Usage examples

CLI 期望输入为 文件全局process.stdin。它将格式化结果输出到 process.stderr 中。

¥The CLI expects input as either a file glob or process.stdin. It outputs formatted results into process.stderr.

你应该在文件 glob 周围添加引号。

¥You should include quotation marks around file globs.

示例 A - recursive

¥Example A - recursive

递归检查 foo 目录中的所有 .css 文件:

¥Recursively linting all .css files in the foo directory:

stylelint "foo/**/*.css"

示例 B - 多个文件扩展名

¥Example B - multiple file extensions

对所有 .css.scss.sass 文件进行 Linting:

¥Linting all .css, .scss, and .sass files:

stylelint "**/*.{css,scss,sass}"

示例 C - stdin

¥Example C - stdin

棉绒 stdin

¥Linting stdin:

echo "a { color: pink; }" | stylelint

示例 D - negation

¥Example D - negation

使用输入 glob 中的否定对除 docker 子文件夹内的文件之外的所有 .css 文件进行 Linting:

¥Linting all .css files except those within docker subfolders, using negation in the input glob:

stylelint "**/*.css" "!**/docker/**"

示例 E - caching

¥Example E - caching

缓存已处理的 .scss 文件 foo 目录:

¥Caching processed .scss files foo directory:

stylelint "foo/**/*.scss" --cache --cache-location "/Users/user/.stylelintcache/"

示例 F - 写报告

¥Example F - writing a report

foo 目录中的所有 .css 文件进行 Linting,然后将输出写入 myTestReport.txt

¥Linting all .css files in the foo directory, then writing the output to myTestReport.txt:

stylelint "foo/*.css" --output-file myTestReport.txt

示例 G - 指定配置

¥Example G - specifying a config

使用 bar/mySpecialConfig.json 作为配置来检查 foo 目录及其任何子目录中的所有 .css 文件:

¥Using bar/mySpecialConfig.json as config to lint all .css files in the foo directory and any of its subdirectories:

stylelint "foo/**/*.css" --config bar/mySpecialConfig.json

示例 H - 使用自定义语法

¥Example H - using a custom syntax

使用自定义语法递归检查 foo 目录中的所有 .css 文件:

¥Recursively linting all .css files in the foo directory using a custom syntax:

stylelint "foo/**/*.css" --custom-syntax path/to/my-custom-syntax.js

示例 I - 打印成功

¥Example I - print on success

确保成功运行时的输出:

¥Ensure output on successful runs:

stylelint -f verbose "foo/**/*.css"

示例 J - 打印配置

¥Example J - print a config

打印用于给定输入文件的配置:

¥Print a configuration used for the given input file:

stylelint test.css --print-config

示例 K - 将报告传输到另一个命令

¥Example K - piping a report to another command

通过管道使用报告作为另一个命令的输入:

¥Use a report as input for another command through piping:

stylelint -f json "*.css" 2>&1 | jq '[.[] | .warnings | length] | add'

退出代码

¥Exit codes

CLI 可以使用以下退出代码退出进程:

¥The CLI can exit the process with the following exit codes:

  • 1 - 致命错误

    ¥1 - fatal error

  • 2 - 棉绒问题

    ¥2 - lint problem

  • 64 - CLI 使用无效

    ¥64 - invalid CLI usage

  • 78 - 无效的配置文件

    ¥78 - invalid configuration file