devtools-detector-fix
v2.0.22
Published
devtools-detector
Downloads
59
Maintainers
Readme
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()
: Returnstrue
if detection is active,false
otherwisestop()
: 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-detector
is loaded before other scripts.
References
- sindresorhus/devtools-detect
- zswang/jdetects
- How to detect if browser DevTools is open in JavaScript? (Chinese)
License
MIT © AEPKILL