「vue-shortkey」を使ってショートカットキーを実装する

「vue-shortkey」を使ってショートカットキーを実装する

vue-shortkeyとは

「vue-shortkey」を使ってショートカットキーを実装する

 

vue-shortkey」は、ショートカットキーを実装するライブラリです。

ショートカットキーによりイベントもしくはフォーカスを設定することができます。

 

 

インストール

以下のnpmCDNを使ってインストールします。

npm

npm install --save vue2-animate

CDN

<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/index.min.js"></script>

 

gitリポジトリは以下から取得できます。

https://github.com/iFgR/vue-shortkey

 

 

導入手順

ショートカットキーを実装します。

1. ライブラリの取り込み

(1)webpack等の場合 ※モジュール版は未検証です。

Vue.use(require('vue-shortkey'))

(2)WEBページの場合

Vue.use(VueShortkey);

2.ショートカットイベントを設定

methodsショートカットキーイベントtheActionマルチイベントtheActionArrowを作成します。

theActionArrowは一つのイベントで複数のショートカットキーを処理します。

 new Vue({
   el: '#app',
   data: {
    name: ''
   },
   methods: {
    theAction: function(){
      alert("['ctrl', 'alt', 'b']");
    },
    theActionArrow:function(event){
      switch (event.srcKey) {
      case 'up':
        alert('up');
        break;
      case 'down':
        alert('down');
        break;
      }
    }
   }
 })

3. テンプレートを準備

イベントマルチイベントフォーカスのテンプレートを準備します。

フォーカスを使用するにはv-shortkey.focusを使用します。

<div id="app">
    <p>イベント:[ctrl + alt + b]</p>
    <button v-shortkey="['ctrl', 'alt', 'b']" @shortkey="theAction()">Open</button>
    <p>マルチイベント:[arrowup] もしくは [arrowdown]</p>
    <button v-shortkey="{up: ['arrowup'], down: ['arrowdown']}" @shortkey="theActionArrow">Joystick</button>
    <p>フォーカス:[alt + i]</p>
    <input type="text" v-shortkey.focus="['alt', 'i']" v-model="name" />
</div>

 

サンプル

※JSFiddle越しだと少し動作が不安定です。一度iframe内をクリックすると動作するようです。

>>専用ページで確認する

 

 

キーの種類

ショートカットキーは以下のものを使用することができます。

Key 設定値
Delete del
Backspace backspace
Insert insert
NumLock numlock
CapsLock capslock
Pause pause
ContextMenu contextmenu
ScrollLock scrolllock
BrowserHome browserhome
MediaSelect mediaselect
Shift shift
Control ctrl
Alt alt
Alt Graph altgraph
Super (Windows or Mac Cmd) meta
Arrow Up arrowup
Arrow Down arrowdown
Arrow Left arrowleft
Arrow Right arrowright
Enter enter
Escape esc
Tab tab
Space space
Page Up pageup
Page Down pagedown
Home home
End end
A - Z a-z
0-9 0-9
F1-F12 f1-f12

 

 

まとめ

ショートカットキーを実装するライブラリでした。

通常のブラウザで利用するには少し面倒ですが、Electoronなどで利用するには便利そうです。

 

今日はこの辺でー

 

  • この記事を書いた人

カバノキ

印刷会社のWEB部隊に所属してます。 WEB制作に携わってから、もう時期10年になります。 普段の業務では、PHPをメインにサーバーサイドの言語を扱っています。 最近のお気に入りはJavascriptです。 Vue.jsを狂喜乱舞しながら、社内に布教中です。

-vue.js
-, , , ,