Migrate from ESLint and Prettier
Это содержимое пока не доступно на вашем языке.
Biome provides dedicated commands to ease the migration from ESLint and Prettier.
If you don’t want to know the details, just run the following commands:
biome migrate eslint --writebiome migrate prettier --writeMigrate from ESLint
Section titled “Migrate from ESLint”Many Biome linter rules are inspired by or identical to the ESLint rules or the rules of an ESLint plugin.
We handle some ESLint plugins such as TypeScript ESLint, ESLint JSX A11y, ESLint React, and ESLint Unicorn.
However, Biome has its own naming convention for its rules.
Biome uses camelCaseRuleName while ESLint uses kebab-case-rule-name.
Moreover, Biome has often chosen to use different names to better convey the intent of its rules.
The source of a rule can be found on the page describing the rule.
You can also find the equivalent Biome rule from an ESLint rule using the dedicated page.
To ease the migration, Biome provides the biome migrate eslint subcommand.
This subcommand will read your ESLint configuration and attempt to port its settings to Biome.
The subcommand is able to handle both the legacy and the flat configuration files.
It supports the extends field of the legacy configuration and loads both shared and plugin configurations.
For flat configuration files, the subcommand will attempt to search for JavaScript extension only (js, cjs, mjs) to be loaded into Node.js.
The subcommand needs Node.js to load and resolve all the plugins and extends configured in the ESLint configuration file.
The subcommand also migrates .eslintignore.
Given the following ESLint configuration:
{ "extends": ["plugin:unicorn/recommended"], "plugins": ["unicorn"], "ignore_patterns": ["dist/**"], "globals": { "Global1": "readonly" }, "rules": { "eqeqeq": "error" }, "overrides": [ { "files": ["tests/**"], "rules": { "eqeqeq": "off" } } ]}And the following Biome configuration:
{ "linter": { "enabled": true, "rules": { "recommended": true } }}Run the following command to migrate your ESLint configuration to Biome.
npx @biomejs/biome migrate eslint --writepnpm exec biome migrate eslint --writebunx --bun biome migrate eslint --writedeno run -A npm:@biomejs/biome migrate eslint --writeyarn exec biome migrate eslint --writeThe subcommand overwrites your initial Biome configuration.
For example, it disables recommended.
This results in the following Biome configuration:
{ "organizeImports": { "enabled": true }, "linter": { "enabled": true, "rules": { "recommended": false, "complexity": { "noForEach": "error", "noStaticOnlyClass": "error", "noUselessSwitchCase": "error", "useFlatMap": "error" }, "style": { "noNegationElse": "off", "useForOf": "error", "useNodejsImportProtocol": "error", "useNumberNamespace": "error" }, "suspicious": { "noDoubleEquals": "error", "noThenProperty": "error", "useIsArray": "error" } } }, "javascript": { "globals": ["Global1"] }, "overrides": [ { "include": ["tests/**"], "linter": { "rules": { "suspicious": { "noDoubleEquals": "off" } } } } ]}For now, biome migrate eslint doesn’t support configuration written in YAML.
By default, Biome doesn’t migrate inspired rules.
You can use the CLI flag --include-inspired to migrate them.
npx @biomejs/biome migrate eslint --write --include-inspiredpnpm exec biome migrate eslint --write --include-inspiredbunx --bun biome migrate eslint --write --include-inspireddeno run -A npm:@biomejs/biome migrate eslint --write --include-inspiredyarn exec biome migrate eslint --write --include-inspiredNote that you are unlikely to get exactly the same behavior as ESLint because Biome has chosen not to implement some rule options or to deviate slightly from the original implementation.
Since ESLint takes VCS ignore files into account, we recommend that you enable Biome’s VCS integration.
Migrate from Prettier
Section titled “Migrate from Prettier”Biome tries to match the Prettier formatter as closely as possible.
However, Biome uses different defaults for its formatter.
For example, it uses tabs for indentation instead of spaces.
You can easily migrate to Biome by running biome migrate prettier --write.
Given the following Prettier configuration:
{ "useTabs": false, "singleQuote": true, "overrides": [ { "files": ["*.json"], "options": { "tabWidth": 2 } } ]}Run the following command to migrate your Prettier configuration to Biome.
npx @biomejs/biome migrate prettier --writepnpm exec biome migrate prettier --writebunx --bun biome migrate prettier --writedeno run -A npm:@biomejs/biome migrate prettier --writeyarn exec biome migrate prettier --writeThis results in the following Biome configuration:
{ "formatter": { "enabled": true, "formatWithErrors": false, "indentStyle": "space", "indentWidth": 2, "lineEnding": "lf", "lineWidth": 80, "attributePosition": "auto" }, "organizeImports": { "enabled": true }, "linter": { "enabled": true, "rules": { "recommended": true } }, "javascript": { "formatter": { "jsxQuoteStyle": "double", "quoteProperties": "asNeeded", "trailingCommas": "all", "semicolons": "asNeeded", "arrowParentheses": "always", "bracketSpacing": true, "bracketSameLine": false, "quoteStyle": "single", "attributePosition": "auto" } }, "overrides": [ { "include": ["*.json"], "formatter": { "indentWidth": 2 } } ]}The subcommand needs Node.js to load JavaScript configurations such as .prettierrc.js.
biome migrate prettier doesn’t support configuration written in JSON5, TOML, or YAML.
Since Prettier takes VCS ignore files into account, we recommend that you enable Biome’s VCS integration.
Copyright (c) 2023-present Biome Developers and Contributors.