Skip to content

Linter (oxlint) ​

  • npm weekly downloads

Oxlint is designed to catch erroneous or useless code without requiring any configurations by default.

INFO

At this stage, Oxlint can be used to fully replace ESLint in small to medium projects.

For larger projects, our advice is to turn off ESLint rules via eslint-plugin-oxlint, and run Oxlint before ESLint in your local or CI setup for a quicker feedback loop.

Features ​

Language Support ​

  • Supports:
    • JavaScript and TypeScript by their extensions js, mjs, cjs, jsx, ts, mts, cts and tsx.
    • <script> content of .vue, .astro and .svelte files.
    • type-aware rules defined by typescript-eslint (preview, requires --type-aware flag and oxlint-tsgolint package).
  • No support for:

Installation ​

Run oxlint directly at the root of your repository:

sh
$ npx oxlint@latest
sh
$ pnpm dlx oxlint@latest
sh
$ yarn dlx oxlint@latest
sh
$ bunx oxlint@latest
sh
$ deno run npm:oxlint@latest

Or save it to your package.json:

sh
$ npm add -D oxlint
sh
$ pnpm add -D oxlint
sh
$ yarn add -D oxlint
sh
$ bun add -D oxlint

oxlint does not require Node.js, the binaries can be downloaded from the latest GitHub releases.

Type-Aware Linting (Preview) ​

Oxlint supports type-aware rules in preview mode. To enable type-aware linting:

  1. Install the required dependency:
sh
$ npx add -D oxlint-tsgolint@latest
sh
$ pnpm add -D oxlint-tsgolint@latest
sh
$ yarn add -D oxlint-tsgolint@latest
sh
$ bunx add -D oxlint-tsgolint@latest
  1. Run oxlint with the --type-aware flag:
sh
$ npx oxlint --type-aware
sh
$ pnpm oxlint --type-aware
sh
$ yarn oxlint --type-aware
sh
$ bunx oxlint --type-aware
sh
$ deno run oxlint --type-aware

For more details and the list of supported type-aware rules, see the type-aware linting announcement.

Command-line Interface ​

See Command-line Interface

Configuration File ​

See Configuration File

Migrate from eslint flat config ​

If you have an existing eslint.config.* file, you can convert it to an .oxlintrc.json config with oxlint-migrate.

Integration ​

ESLint ​

If you are looking for a way to use oxlint in projects that still need ESLint, you can use eslint-plugin-oxlint to turn off ESLint rules that are already supported by oxlint. So you can enjoy the speed of oxlint while still using ESLint.

lint-staged ​

package.json
json
{
  "lint-staged": {
    "**/*.{js,mjs,cjs,jsx,ts,mts,cts,tsx,vue,astro,svelte}": "oxlint"
  }
}

VSCode Extension ​

Download the official VSCode extension from the

Zed Extension ​

https://zed.dev/extensions?query=oxc

Continuous Integration ​

Since oxlint only takes a few seconds to run, we recommend running oxlint before ESLint for faster feedback loops.

GitHub Actions ​

yaml
jobs:
  oxlint:
    name: Lint JS
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - run: npx --yes oxlint@0.0.0 --deny-warnings # change to the latest release

It is advised to pin the version, otherwise CI may fail after a new release.

pre-commit ​

.pre-commit-hooks.yaml
yaml
repos:
  - repo: https://github.com/oxc-project/mirrors-oxlint
    rev: v0.0.0 # change to the latest version
    hooks:
      - id: oxlint
        verbose: true

Unplugin ​

https://www.npmjs.com/package/unplugin-oxlint

Vite plugin ​

https://www.npmjs.com/package/vite-plugin-oxlint

System Requirements ​

oxlint is built for darwin-arm64, darwin-x64, linux-arm64, linux-x64, win32-arm64 and win32-x64.

Released under the MIT License.