Javascript keyboard shortcuts for web application

2019-02-01 23:22发布

问题:

I want to develop a web application, which should (idealy) be fully usable via the keyboard. I know how to handle keyboard events in javascript, but managing them for a larger application is quite boring. I wonder if somebody knows a library which makes that process easier. Any hint? Please not that I'm not interested in a full blown Web GUI framework. I want to keep control over my webpage/app.

回答1:

Check out my project:

https://github.com/oscargodson/jkey

And demos:

http://oscargodson.github.com/jKey/

Feel free to use it and if you want, contribute :)



回答2:

I just developed one of my own called mousetrap. Check it out http://craig.is/killing/mice



回答3:

You can use Hotkeys - plugin for JQuery. JQuery is quite lightweight javascript library - is required js file for using Hotkeys.



回答4:

You could start by reading about the accesskey attribute:

This attribute assigns an access key to an element. An access key is a single character from the document character set. Note. Authors should consider the input method of the expected reader when specifying an accesskey.
[...]
The invocation of access keys depends on the underlying system. For instance, on machines running MS Windows, one generally has to press the "alt" key in addition to the access key. On Apple systems, one generally has to press the "cmd" key in addition to the access key.

You can also put the accesskey attribute on <a> elements, an example of this usage can be found on the "Random Article" sidebar link on Wikipedia.



回答5:

I would strongly encourage you to check out Thomas Fuchs' keymaster for doing keyboard shortcuts in webapps: https://github.com/madrobby/keymaster

It makes it quite simple:

// define short of 'a'
key('a', function(){ alert('you pressed a!') });

// returning false stops the event and prevents default browser events
key('ctrl+r', function(){ alert('stopped reload!'); return false });

// multiple shortcuts that do the same thing
key('⌘+r, ctrl+r', function(){ });


回答6:

This one is very easy to use.

Ex:

shortcut.add("Up",     // key
             go_up()); // function


回答7:

You could use the accesskey html attribute as it would then make your webapp accessible.

Use the KeyTips jQuery Plugin to display them to the user in a similar way to Office Ribbon keyboard shortcuts.

Try the Demo. Code on Github.

Note that Wikipedia page on accesskey lists the modifier keys to invoke access keys for different browsers.

See also the A List Apart article: Accesskeys: Unlocking Hidden Navigation