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

JavaScript - アロー関数(ラムダ式)

次の記事 >

JavaScript - 可変長引数

JavaScript

JavaScript - クロージャー

公開日:2018-11-29
更新日:2019-05-11

1. 概要

クロージャーは、プロパティとメソッドを1つ持ったクラスのようなものです。
通常、関数内で定義された変数は、関数が終了すると破棄されますが、
どこかでその変数を参照している場合は、関数を抜けても破棄されずに保持されます。
これを利用して、特定の関数専用のグローバル変数を減らすことができます。

2.1 クロージャーを使わない場合

count がどこからでもアクセスできるため、間違って使われると、counter() の値がずれます。

var count = 0;

function counter() {
return ++count;
}

console.log( counter() ); //1
count++;                  //間違って使われると、ここから値がずれる
console.log( counter() ); //3
console.log( counter() ); //4

2.2 クロージャーを使う場合

外部から count を参照することができないため、誤って使われることがなくなります。
最初に呼び出す関数(getCounter)は、コンストラクタとしての初期化処理を行うことができます。

function getCounter() {
var count = 0;

return function() {
return ++count;
}
}

var counter = getCounter();
console.log( counter() ); //1
//count++;                //エラー。count は宣言されていないと言われる
console.log( counter() ); //2
console.log( counter() ); //3

2.3 オブジェクトを使う場合

JavaScript の場合、関数に動的にプロパティを追加できるため、
クロージャーを使わない方がシンプルに書けます。
但し、毎回 if が実行されていることに注意してください。

var counter = function () {
if (this.count == undefined) this.count = 0;
return ++this.count;
}
console.log( counter() ); //1
console.log( counter() ); //2
console.log( counter() ); //3


< 前の記事

JavaScript - アロー関数(ラムダ式)

次の記事 >

JavaScript - 可変長引数

YouTube X

新着一覧

  • テーブル結合(CROSS JOIN、INNER JOIN、LEFT JOIN)MariaDB
  • 楽観ロック・悲観ロックMariaDB
  • カレントリードMariaDB
  • インデックスMariaDB
  • 論理削除(ソフトデリート)MariaDB
  • awk(オーク)の使い方についてLinux
  • NOT NULL 制約と NULL を許容した時の動作MariaDB
  • 外部キー制約MariaDB
  • MySQL と MariaDB の関係MariaDB
  • Docker で PostgreSQL のコンテナの使用Linux

アーカイブ

  • 2026/01
  • 2025/12
  • 2025/11
  • 2025/10
  • 2025/09
  • 2025/08
  • /00

以前のカテゴリー一覧

  • 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.

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