# Hotkeys
[data:image/s3,"s3://crabby-images/6f6ab/6f6ab4413055f557046055b1f7275ee8ea1228e8" alt=""](https://github.com/jaywcjlove/hotkeys/issues) [data:image/s3,"s3://crabby-images/b7ed7/b7ed7ed8ffe4bebeb13668a31d788adbf732ec36" alt=""](https://github.com/jaywcjlove/hotkeys/network) [data:image/s3,"s3://crabby-images/ddeb5/ddeb5255dbcfefd0702ac8ca795c282f86408bd6" alt=""](https://github.com/jaywcjlove/hotkeys/stargazers) [data:image/s3,"s3://crabby-images/38f27/38f27a58746db4eee37fbb36906095b8c045216e" alt=""](https://github.com/jaywcjlove/hotkeys/releases) data:image/s3,"s3://crabby-images/775d8/775d84baf8547fc2ad04fa82597a27a6f4c2e6d8" alt="" [data:image/s3,"s3://crabby-images/9ad9c/9ad9cf3bb7c4ed6b7849c8c51791aec7acc20bbb" alt="Build Status"](https://www.travis-ci.org/jaywcjlove/hotkeys) [data:image/s3,"s3://crabby-images/c1639/c1639e7ced4a4b29239c9a621027f08bb8855628" alt="Coverage Status"](https://coveralls.io/github/jaywcjlove/hotkeys?branch=master) [data:image/s3,"s3://crabby-images/22374/223740cd6478632a31919e8fa460df46f1a18242" alt="jaywcjlove/sb"](./README-zh.md)
HotKeys.js is an input capture library with some very special features, it is easy to pick up and use, has a reasonable footprint (~3kb) (gzipped: 1.73kb), and has no dependencies. It should not interfere with any JavaScript libraries or frameworks. Official document [demo preview](http://jaywcjlove.github.io/hotkeys).
```shell
╭┈┈╮ ╭┈┈╮ ╭┈┈╮
┆ ├┈┈..┈┈┈┈┈.┆ └┈╮┆ ├┈┈..┈┈┈┈┈..┈┈.┈┈..┈┈┈┈┈.
┆ ┆┆ □ ┆┆ ┈┤┆ < ┆ -__┘┆ ┆ ┆┆__ ┈┈┤
╰┈┈┴┈┈╯╰┈┈┈┈┈╯╰┈┈┈┈╯╰┈┈┴┈┈╯╰┈┈┈┈┈╯╰┈┈┈ ┆╰┈┈┈┈┈╯
╰┈┈┈┈┈╯
```
## Usage
You will need `Node.js` installed on your system.
```shell
$ npm install hotkeys-js --save
```
```js
import hotkeys from 'hotkeys-js';
hotkeys('f5', function(event, handler){
// Prevent the default refresh event under WIDNOWS system
event.preventDefault()
alert('you pressed F5!')
});
```
Or manually download and link **hotkeys.js** in your HTML:
```html