Listen to events on the document anywhere
npm install vue-global-eventsThanks to Vue’s event modifiers, handling events is extremely easy however, you’re limited to DOM element events.
We decided to change that, so now you can register global events (for example application shortcuts) just like you would listen to events on a component. No need to worry about unregistration either. You can toggle the events with a single v-if. Works with SSR too.
import GlobalEvents from 'vue-global-events'
// register globally
Vue.component(GlobalEvents)
// or locally
export default {
components: { GlobalEvents },
// rest of your component
}After that you can register global events like this:
<GlobalEvents
v-if="listenersConnected"
@keyup.ctrl.tab="nextTab"
@keyup.ctrl.shift.tab="previousTab"
@keyup.space="pause"
@contextmenu="openMenu"
/>- type:
Function - default:
() => true
event: Native Event Objecthandler: method passed toGlobalEventscomponenteventName: event name with key modifiers
filter should return false to prevent the execution of a handler:
<GlobalEvents
:filter="(event, handler, eventName) => event.target.tagName !== 'INPUT'"
@keyup.prevent.space.exact="nextTab"
/>In the example above event would be the native keyup Event Object, handler would be the method nextTab and eventName would be the string keyup. eventName can contain key modifiers if used
- Always
.preventevents with.ctrland other modifiers as browsers may be using them as shortcuts. - Do not use shortcuts that are used by the system or that the browser does not allow you to
.preventDefault(). The list includesCtrl+Tab/Cmd+Tab,Ctrl+W/Cmd+W. You can find more information in this StackOverflow answer. - Prefer using actual characters to keyCodes whenever possible:
@keydown.+for detecting the plus sign. This is important because symbols and numbers on the digit row will provide different keyCodes depending on the layout used. - You can add custom keyCodes to
Vue.config.keyCodes. This is especially useful for numbers on the digit row: addVue.config.keyCodes.digit1 = 49so you can write@keydown.digit1because writing@keydown.1will trigger whenkeyCode === 1. - About using
keyupwith modifiers like.ctrlor.shift: the keyup event is triggered when a key is released and that's also when theevent.ctrlKeyis checked, which if you just released, will be false. This is becausectrl,shiftandaltare checked differently. If you want to trigger on thekeyupevent of a modifier, you need to use its keycode (check it here. For example, for thectrlkey, that would be:@keyup.17. You can also use the advice above this one to provide it a name like ctrlkey.
Run tests in watch mode:
npm run devJust use poi
# if not yet installed
npm i -g poi
poi index.jsDamian Dulisz @shentao
Eduardo San Martin Morote @posva