命令行接口 (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
¥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