Build extensions for Chrome, Edge, and Firefox. No build config required.
npx extension@latest create my-extension
cd my-extension
npm run dev
Works with npm, pnpm, yarn, and bun.
Documentation · Templates · Examples · Discord
Browser extensions ship with the worst dev experience in modern web. Manifest V3 fragmentation, browser-specific quirks, no hot reload for content scripts, and a separate build pipeline for every target. Extension.js fixes that.
extension build --zip, ready for the Chrome Web Store and Firefox Add-onsdevDependencyOr skip the install and try a live template in your browser.
If you have used Plasmo, WXT, or CRXJS, here is what Extension.js does that the others do not:
| Capability | Extension.js |
|---|---|
| Run any GitHub sample directly | extension dev https://github.com/.../sample |
| Managed browser binaries | extension install firefox downloads an isolated build |
| Cross-browser HMR for content scripts | Built in, no plugin glue |
| Production zip for the stores | extension build --zip |
| Framework agnostic | Vanilla, TS, React, Vue, Svelte, Preact, no lock-in |
| Custom Chromium and Gecko binaries | --chromium-binary, --gecko-binary |
| ESNext |
Try out | TypeScript
Try out | WASM
Try out | React
Try out | Vue
Try out | Svelte
Try out | Preact
Try out |
Use these flags with extension dev, extension start, or extension preview:
--browser <chrome | edge | firefox>--chromium-binary <path-to-binary>--gecko-binary <path-to-binary># Chrome (system default)
npx extension@latest dev --browser=chrome
# Edge
npx extension@latest dev --browser=edge
# Custom Chrome/Chromium path
npx extension@latest dev --chromium-binary "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome"
# Custom Firefox path
npx extension@latest dev --gecko-binary "/Applications/Firefox.app/Contents/MacOS/firefox"
| Google Chrome |
✅ Supported | Microsoft Edge
✅ Supported | Mozilla Firefox
✅ Supported | Apple Safari
🚙 Next | Chromium-based
✅ Supported | Gecko-based
✅ Supported |
Build a production-ready bundle and zip it for submission to the Chrome Web Store, Edge Add-ons, or Firefox AMO:
# Production build
npx extension@latest build
# Production build packaged as a ZIP
npx extension@latest build --zip
# Per-browser builds
npx extension@latest build --browser=firefox --zip
Useful flags:
--zip packages the build into a ZIP ready for store upload--zip-source includes source files for store source-code review--zip-filename <name> controls the output filename--polyfill enables the cross-browser webextension polyfillSkip the system-install dance. Extension.js can download and manage isolated browser binaries for clean dev sessions:
# Install a managed Firefox build
npx extension@latest install firefox
# Install Chrome and Edge in one go
npx extension@latest install --browser=all
# Print where managed browsers live
npx extension@latest install --where
Install Extension.js as a dev dependency and wire up your scripts.
npm install extension@latest --save-dev
{
"scripts": {
"build": "extension build",
"dev": "extension dev",
"preview": "extension preview"
}
}
Run npm run dev to develop, npm run build for production, and npm run preview to inspect the production output. See it in action.
Pull any sample from Chrome Extension Samples and run it directly:
npx extension@latest dev https://github.com/GoogleChrome/chrome-extensions-samples/tree/main/functional-samples/sample.page-redder --browser=edge
MIT (c) Cezar Augusto and the Extension.js authors.
$ claude mcp add extension.js \
-- python -m otcore.mcp_server <graph>