【Amazon】人気の商品が日替わりで登場!
毎日お得なタイムセール!商品をみる

【JavaScript】blurイベントとは?フォーカスが外れた時に処理を行う

こちらの記事では、JavaScriptのblurイベントについてサンプルコードを用いて分かりやすく解説しています。

JavaScriptの学習におすすめ書籍
1冊ですべて身につくJavaScript入門講座
総合評価
( 5 )
メリット
  • 誰でも分かるように嚙み砕いて説明してくれる
  • アニメーションの知識が深く学べる
  • 1つのWebサイトを作りながら学べる
先輩くん

Amazon Kindle Unlimitedに登録すると、月額980円で読み放題だからオススメだよ!

後輩ちゃん

初回30日間は無料だから、まだ登録したことのない人はぜひ試してみてね!

全プログラマー必見!
変数名/関数名にもう悩まない!
リーダブルコード
総合評価
( 5 )
メリット
  • 美しいコードが書けるが自然と書けるようになる
  • 他の開発者が理解しやすいコードになる
著:Dustin Boswell, 著:Trevor Foucher, 解説:須藤 功平, 翻訳:角 征典
¥2,640 (2023/07/23 02:48時点 | Amazon調べ)
目次

blurイベントとは

blurイベントとは、ユーザーがテキストフィールドやテキストエリアなどに対して一度フォーカスをあてている状態から外したタイミングで実行されるイベントです。

同じフォーカス系イベントである、focusイベント(クリックやキーボードのTabキーでテキストフィールドやテキストエリアなどに対してフォーカスした時にイベント実行)とは対照的のイベントになります。

blurイベントの使い方

blurイベントは「addEventListenerメソッド」「onblurプロパティ」「onblur属性」の3つの書き方があります。

▼トリガーになる要素を取得(addEventListenerとonblurプロパティで使用)
const elem = document.getElementById('js-elem'); // トリガーになる要素を取得

▼addEventListenerメソッド
elem.addEventListener('blur',function(){ // 第一引数にblurを指定
  // 処理を記述
});

▼onblurプロパティ
elem.onblur = function(){
  // 処理を記述
};
▼onblur属性
<form>
  <input type="text" placeholder="テキストを入力してください" onblur="blurEvent();">
</form>

<script>
function blurEvent(){
  // 処理を記述
}
</script>

サンプルコード

こちらで紹介するサンプルコードは、テキストフィールドに文字を入力してフォーカスを外すと入力した文字が下に表示されます。

実行結果
入力されたテキスト:
<form>
  <input id="input-text" type="text" placeholder="テキストを入力してください">
  <p>入力されたテキスト:<span id="output-text"></span></p>
</form>

<script>
window.addEventListener('DOMContentLoaded',function(){
  const inputText = document.getElementById('input-text');   // ①
  const outputText = document.getElementById('output-text'); // ①
  
  inputText.addEventListener('blur',function(e){ // ②
    outputText.textContent = e.target.value; // ③
  });
});
</script>
サンプルコード解説
  • blurイベントを設定する対象のテキストフィールド要素と入力した文字列を表示させる要素を取得
  • addEventListenerメソッドの第一引数にblurを指定
  • blurイベントが実行された時にe.target.valueでテキストフィールドの値を取得し表示させる

ブログランキング・にほんブログ村へ PVアクセスランキング にほんブログ村 FC2 Blog Ranking

よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!
目次