9cubed
ブログ | Tailwind | Vite | Python | Node.js | Linux | PowerShell | その他 | 将棋ウォーズ | 歌の練習
< 前の記事

jQuery - changeイベント

次の記事 >

jQuery - selectイベント

jQuery

jQuery - イベントでのアロー関数(ラムダ式)の使用について

公開日:2018-12-21
更新日:2019-05-14

1. 概要

イベントでアロー関数(ラムダ式)を使用した場合、$(this) の値が無名関数(匿名関数)の場合と異なるため、注意が必要です。
例えば、アロー関数(ラムダ式)の場合は、$(function() { } の中で定義した場合と、外で定義した場合では、$(this) の値が異なります。

//無名関数(匿名関数)
$(セレクタ).on("click", function(e) {
	//$(this) は、$(セレクタ)の要素
});

//アロー関数(ラムダ式)
$(セレクタ).on("click", (e) => {
	//$(this) は、実行した環境によって変わる
});

2. サンプル

ボタンをクリックすると、ボタンの色が変わります。

<!DOCTYPE html><html><head><meta charset="UTF-8"><title>jQuery</title><style>body{color:#fff; background-color:#000;}</style></head>
<body>
  <script src="https://code.jquery.com/jquery-3.3.1.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script>

  <input type="button" id="btn1" value="無名関数(匿名関数)" />
  <input type="button" id="btn2" value="アロー関数(ラムダ式) その1" />
  <input type="button" id="btn3" value="アロー関数(ラムダ式) その2" />

  <div id="msg"></div>
  <script>
    
    $(function() {

      //無名関数(匿名関数)
      $("#btn1").on("click", function(e) {
        $(this).css("background-color", "lightblue");
      });

      //アロー関数(ラムダ式) その1
      $("#btn2").on("click", (e) => {
        $(this)
          .children()
          .children("body")
          .find("#btn2")
          .css("background-color", "lightblue");
      });

    });
    
    //アロー関数(ラムダ式) その2
    $("#btn3").on("click", (e) => {
      
      var win = $(this)[0];

      //ボタンの背景色を薄い青にします
      var btn = win.document.getElementById("btn3");
      $(btn).css("background-color", "lightblue");

      //ボタンのフォントを大きくして、青にします
      $(win.document)
        .children()
          .children("body")
          .find("#btn3")
          .css("color", "blue")
          .css("font-size", "20px");
      
      if ($.isWindow( win )) {
        win.alert("$(this) は window です。");
      }
       
    });

  </script>
</body></html>

実行結果:画面



< 前の記事

jQuery - changeイベント

次の記事 >

jQuery - selectイベント

YouTube X

新着一覧

  • SCSS のインストールVite
  • Tailwind CSS のプロジェクトの作成Tailwind
  • TypeScriptのプロジェクトの作成Vite
  • Flask のインストールと動作確認Python
  • 簡易Webサーバーの作成Python
  • pipeline で文章の生成Python
  • pipeline で文章の要約Python
  • 音声から文字起こしPython
  • Node.js のインストールNode.js
  • .ps1(PowerShellスクリプト)を実行可能にするPowerShell

アーカイブ

  • 2025/12
  • 2025/11
  • 2025/10
  • 2025/09
  • 2025/08

以前のカテゴリー一覧

  • CakePHP3
  • CentOS7
  • HTML・CSS・JavaScript
  • Haskell
  • JavaScript
  • Kotlin
  • Laravel5
  • PHP
  • Python
  • Ruby
  • RubyOnRails5
  • TypeScript
  • Vue.js
  • Webサーバ講座
  • Webプログラミング講座
  • jQuery
  • linux
  • パソコン講座
  • ブログ
  • プログラミング講座
  • メモ帳作成講座
  • 数学

Copyright © 9cubed. All Rights Reserved.

プライバシーポリシー 利用規約
▲