Skip to main content
ESLint Interlace
Plugin: modernization

Overview

ESLint rules for modernizing JavaScript to ES2022+ syntax

Live from GitHub

This content is fetched directly from README.md on GitHub and cached for 1 hour.

Modern JavaScript

Upgrade your codebase to ES2022+ syntax with auto-fixable rules.


Live README from GitHubfrom eslint-plugin-modernization/README.md, cached for 1 hour.Edit on GitHub
ESLint Interlace Logo

Modernization rules — prefer modern ES idioms over legacy patterns.

NPM VersionNPM DownloadsPackage LicenseCodecovSince Dec 2025

⭐ If this plugin caught a real bug for you, star the repo — it's the signal that keeps these rules maintained.

Description

This plugin provides Modernization rules — prefer modern ES idioms over legacy patterns.

Philosophy

Interlace fosters strength through integration. Instead of stacking isolated rules, we interlace security directly into your workflow to create a resilient fabric of code. We believe tools should guide rather than gatekeep, providing educational feedback that strengthens the developer with every interaction.

Getting Started

npm install eslint-plugin-modernization --save-dev

⚙️ Configuration Presets

PresetDescription
recommendedBalanced modernization for most projects
strictAll rules as errors for aggressive modernization

🏢 Usage Example

// eslint.config.js
import modernization from 'eslint-plugin-modernization';

export default [
  modernization.configs.recommended,

  // Or be strict about modernization
  // modernization.configs.strict,
];

Why These Rules?

no-instanceof-array

instanceof Array fails across different realms (iframes, workers). Array.isArray() is the correct, reliable check.

// ❌ Bad: Fails across realms
if (value instanceof Array) {
}

// ✅ Good: Works everywhere
if (Array.isArray(value)) {
}

prefer-at

Array.at() provides cleaner negative index access (ES2022+).

// ❌ Bad: Verbose negative index access
const last = arr[arr.length - 1];

// ✅ Good: Clean ES2022+ syntax
const last = arr.at(-1);

prefer-event-target

EventTarget is the native browser API and doesn't require Node.js polyfills.

// ❌ Bad: Requires polyfill in browsers
import { EventEmitter } from 'events';

// ✅ Good: Native browser API
const target = new EventTarget();

📦 Compatibility

PackageVersion
ESLint^8.0.0 || ^9.0.0 || ^10.0.0
Node.js>=18.0.0

See the ESLint Version Support Policy — current ecosystem share data, the 20% gate, and the forward-looking exception that covers v10.

Rules

Legend

IconDescription
💼Recommended: Included in the recommended preset.
⚠️Warns: Set to warn in recommended preset.
🔧Auto-fixable: Automatically fixable by the --fix CLI option.
💡Suggestions: Providing code suggestions in IDE.
🚫Deprecated: This rule is deprecated.
🟢Type-unaware: AST-only, runs in oxlint JS-plugin tier.
🟡Type-aware (refining): pure-AST primary path; types refine precision.
🟠Type-aware (graceful): requires TS program; silent without it.
RuleCWEOWASPCVSSDescription🧠💼⚠️🔧💡🚫
no-instanceof-arrayPrefer Array.isArray() over instanceof Array for reliable type checking across different JavaScript realms…🟢💡
prefer-atPrefer using Array.at() for accessing elements, especially with negative indices🟢💡
prefer-event-targetPrefer EventTarget over EventEmitter for isomorphic code🟢💡
prefer-template-literalPrefer template literals over string concatenation with runtime values🟢

Part of the Interlace ESLint Ecosystem — AI-native security plugins with LLM-optimized error messages:

PluginDownloadsDescription
eslint-plugin-secure-codingdownloadsGeneral security rules & OWASP guidelines.
eslint-plugin-pgdownloadsPostgreSQL security & best practices.
eslint-plugin-node-securitydownloadsNode.js core-module security (fs, child_process, vm, crypto, Buffer).
eslint-plugin-jwtdownloadsJWT security & best practices.
eslint-plugin-browser-securitydownloadsBrowser-specific security & XSS prevention.
eslint-plugin-express-securitydownloadsExpress.js security hardening rules.
eslint-plugin-lambda-securitydownloadsAWS Lambda security best practices.
eslint-plugin-nestjs-securitydownloadsNestJS security rules & patterns.
eslint-plugin-mongodb-securitydownloadsMongoDB security best practices.
eslint-plugin-vercel-ai-securitydownloadsVercel AI SDK security hardening.
eslint-plugin-import-nextdownloadsNext-gen import sorting & architecture.

⭐ Support & follow

If this plugin caught a real bug for you, star the repo — stars are the signal that keeps the Interlace ESLint ecosystem maintained — and follow the writeups on Dev.to for the benchmarks and security research behind these rules.

GitHub stars

📄 License

MIT © Ofri Peretz

ESLint Interlace Plugin

View README.md on GitHub →

On this page

No Headings