Vue のキーボードイベント監視の概要

Vue のキーボードイベント監視の概要

キー修飾子

キーボード イベントをリッスンする場合、詳細なキーを確認する必要があることがよくあります。 Vue では、キーボード イベントをリッスンするときに v-on にキー修飾子を追加できます。

<!-- `key` が `Enter` の場合にのみ `vm.submit()` を呼び出します -->
<入力v-on:keyup.enter="送信">

KeyboardEvent.key によって公開される有効なキー名をケバブケースに変換するだけで、修飾子として使用できます。

<input v-on:keyup.page-down="onPageDown">

必要に応じて古いブラウザをサポートするために、Vue は最も一般的なキーコードのエイリアスを提供します。

  • -入力
  • - タブ
  • - 削除(「Delete」キーと「Backspace」キーをキャプチャします)
  • -ESC
  • - 空間
  • - 上
  • - 下
  • -左
  • - 右

グローバル config.keyCodes オブジェクトを介してキー修飾子のエイリアスをカスタマイズすることもできます。

// `v-on:keyup.f1` を使うことができます
Vue.config.keyCodes.f1 = 112

システム修飾キー

次の修飾子を使用すると、対応するキーが押されたときにのみマウスまたはキーボード イベントをトリガーするリスナーを実装できます。

  • - .ctrl
  • - .alt
  • - 。シフト
  • - .メタ

何かをする
キーエイリアスとは異なり、修飾キーを keyup イベントで使用する場合、イベントがトリガーされたときに通常のキーを押す必要があります。つまり、keyup.ctrl をトリガーしたい場合は、ctrl キーを押しながら他のキーを放す必要があります。単に ctrl キーを放すだけではイベントはトリガーされません。

<!-- トリガーするには Alt + C を離します -->
<input @keyup.alt.67="クリア">
 
<!-- Alt キーを押しながら任意のキーを離すことでトリガーされます-->
<input @keyup.alt="other"><!-- Ctrl + Enter キーを押すとトリガーされます--><input @keydown.ctrl.13="submit">

elementUI 入力の場合、elementUI が入力をカプセル化し、ネイティブ イベントが機能しないため、最後に .native を追加する必要があります。

<input v-model="form.name" placeholder="ニックネーム" @keyup.enter="送信">

<el-input v-model="form.name" placeholder="ニックネーム" @keyup.enter.native="送信"></el-input>

.exact 修飾子

.exact 修飾子を使用すると、システム修飾子の正確な組み合わせによってどのイベントがトリガーされるかを制御できます。

<!-- Alt キーまたは Shift キーを同時に押した場合でも、この処理が実行されます -->
<button v-on:click.ctrl="onClick">A</button>

<!-- Ctrl キーが押されたときにのみトリガーされます-->
<button v-on:click.ctrl.exact="onCtrlClick">A</button>

<!-- システム修飾子が押されていない場合にのみトリガーされます-->
<button v-on:click.exact="onClick">A</button>

マウスボタン修飾子

  • 。左
  • 。右
  • 。真ん中

これらの修飾子は、ハンドラー関数が特定のマウス ボタンにのみ応答するように制限します。

システムキーの組み合わせ

グローバルキー操作方法を監視したい場合、当然ながら、それをページ要素にバインドすることはできません。

マウントして監視できます:

マウント() {
  document.onkeydown = 関数 (イベント) {
    キーを window.event.keyCode とします。
    if (キー === 65 && event.ctrlKey) { 
      // ctrl+A キーの組み合わせをリッスンします。window.event.preventDefault(); // ブラウザのデフォルトのショートカット キーをオフにします。console.log('crtl+ a キーの組み合わせ')    
    } そうでない場合、key === 83 && event.ctrlKey) {       
      window.event.preventDefault(); //ブラウザのショートカットキーを閉じる console.log('Save');
    }
  }
}

上記の例から、shift、control、Alt は JS では「window.event.shiftKey」、「window.event.ctrlKey」、および「window.event.altKey」に置き換えることもできることがわかります。

付録 - キーボードボタンのキーコード表

以上がVueのキーボードイベント監視の詳細な概要です。Vueのキーボードイベント監視の詳細については、123WORDPRESS.COMの他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • Vue プロジェクトのソフト キーボード入力により検索イベントがトリガーされる
  • Vue キーボード入力イベントの例の説明
  • Vue でキーボード イベントをリッスンする簡単な方法 [推奨]
  • Vue キーボードイベントの使用法の概要
  • Vueのキーボードイベントの詳細な説明

<<:  DockerプライベートイメージライブラリとAlibaba CloudオブジェクトストレージOSSの簡単な分析

>>:  MySQL 5.7.17 のインストールと使用方法のグラフィックチュートリアル

推薦する

データベース管理に役立つ 5 つの MySQL GUI ツール

MySQL には多くのデータベース管理ツールがあります。作業効率の向上に役立つ優れた GUI ツール...

MySQL 8.0 の新機能 - チェック制約の紹介

目次序文チェック制約作成、削除、表示制限要約する序文MySQL 8.0 では、チェック制約という非常...

フロントエンドの面接の質問の最も包括的なコレクション

HTML+CSS 1. WEB 標準と W3C の理解と知識<br /> タグを閉じ、小...

MySql マスタースレーブレプリケーションメカニズムの包括的な分析

目次マスタースレーブレプリケーションメカニズム非同期レプリケーション準同期レプリケーションマスタース...

Vue の匿名スロットと名前付きスロットの詳細な説明

目次1. 匿名スロット2. 名前付きスロット要約するスロット (slot) は、Vue のコンテンツ...

iframeを指すaタグのターゲットの名前とIDの違い

コードをコピーコードは次のとおりです。 <iframe id="myFrameId&...

ウェブページの画像の回転を実現するjs

この記事では、Webページの画像の回転を実現するためのjsの具体的なコードを参考までに共有します。具...

MySQL ベースのシーケンス実装方法

チームは新しいフレームを交換しました。すべての新しいビジネスでは、新しいフレームワークと新しいデータ...

WeChatアプレットでSVGアイコンを使用する方法

SVG は、さまざまな利点があるため、近年広く使用されています。残念ながら、WeChat ミニプログ...

VMware および CentOS システムのインストール方法 - ルート パスワードをリセットする

今日のタスク1. Linuxディストリビューションの選択2.vmwareが仮想マシン(centos)...

MySQL 8.0.22 のダウンロード、インストール、設定方法のグラフィックチュートリアル

参考までにMySQL 8.0.22をダウンロードしてインストールしてください。具体的な内容は次のとお...

Linux システムでの nginx サーバーのインストールと負荷分散構成の詳細な説明

nginx (エンジン x) は、高性能な HTTP およびリバース プロキシ サーバー、メール プ...

Vueページの初回読み込み最適化の全プロセス

目次序文1. 画像の最適化2. .mapファイルの生成を無効にする3. ルーティングの遅延読み込み4...

dockercompose を使用して springboot-mysql-nginx アプリケーションをビルドする

前回の記事では、Docker を使用して、コンパイルされた jar パッケージをイメージに組み込む ...