0.0.3 • Published 11 months ago
devtools-detector-fix v0.0.3
devtools-detector 
Installation
npm install devtools-detector --save
Usage
ES6 & TypeScript
import { addListener, launch } from 'devtools-detector';
const view = document.createElement('div');
document.body.appendChild(view);
// 1. Add listener
addListener((isOpen) => {
view.innerText = isOpen ? 'DevTools status: open' : 'DevTools status: closed';
});
// 2. Launch detection
launch();AMD
require(['devtools-detector'], function (devtoolsDetector) {
const view = document.createElement('div');
document.body.appendChild(view);
devtoolsDetector.addListener(function (isOpen) {
view.innerText = isOpen
? 'DevTools status: open'
: 'DevTools status: closed';
});
devtoolsDetector.launch();
});No Module System
<script src="node_modules/devtools-detector/lib/devtools-detector.js"></script>
<script>
const view = document.createElement('div');
document.body.appendChild(view);
devtoolsDetector.addListener(function (isOpen) {
view.innerText = isOpen
? 'DevTools status: open'
: 'DevTools status: closed';
});
devtoolsDetector.launch();
</script>Browser Support
- IE9+ (requires Promise polyfill)
- Edge
- Chrome
- Firefox
- Safari
- Opera
Types & API
DevtoolsDetail
interface DevtoolsDetail {
isOpen: boolean;
checkerName: string;
}Listener
type DevtoolsDetectorListener = (
isOpen: boolean,
detail?: DevtoolsDetail
) => void;Methods
launch(): Start detectionisLaunch(): Returnstrueif detection is active,falseotherwisestop(): Stop detectionaddListener(listener: DevtoolsDetectorListener): Add a listenerremoveListener(listener: DevtoolsDetectorListener): Remove a listenersetDetectDelay(value: number): Set detection loop delay time. Ifvalue <= 0, detection stops.crashBrowserCurrentTab(): Crash the current browser tab (tested only on Chrome)// Example: crash the current browser tab 2 seconds after DevTools is opened import { addListener, crashBrowserCurrentTab } from 'devtools-detector'; addListener(function (isOpen) { if (isOpen) { setTimeout(crashBrowserCurrentTab, 2000); } });crashBrowser(): Crash all browser tabs (tested only on Chrome)
Caveats
- In Firefox, if DevTools is undocked, it's only detected when switching to the Console Panel.
- Ensure that
devtools-detectoris loaded before other scripts.
References
- sindresorhus/devtools-detect
- zswang/jdetects
- How to detect if browser DevTools is open in JavaScript? (Chinese)
License
MIT © AEPKILL