JavaScript

JavaScriptでは「変数のスコープ」を正しく理解してエラーを減らそう!

scope

変数の「スコープ」は正しく理解しないと、エラーにならないエラーが起きて相当こまることになっちゃいます。
実際、デバッグしてエラーはないのに期待している効果が得られず、原因を見つけるのに予想以上に時間を消費してしまったことがあるんです。

そんなわけでおさらい。

JavaScriptのスコープは大きく分けて2つです。

  1. グローバルスコープ
  2. その名の通り関数の外、トップレベルコードのスコープです。
    これは分かりやすいですね。
    関数の外で変数を宣言しておけば、どこでも使えちゃうってわけです。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    
    //グローバル変数
    var x = 0;
     
    function f(){
        x = 2;
        print(x);
    }
     
    function f2(){
        print(x);
        x = 3;
        print(x);
    }

    結果はこんな感じ。

    1
    2
    3
    
    2
    2
    3
  3. 関数スコープ(ローカルスコープ)
  4. こちらも名前の通り関数の中で宣言した変数ですね。
    注意点は、関数内の変数は宣言した行とは関係なく、その関数内で有効ってこと。
    だから関数内の変数は関数の冒頭にまとめておくようにしています。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    
    function f(){
        //関数変数
        var x = 2;
        print(x);
    }
     
    function f2(){
        //関数変数
        print(x);
        //関数変数
        var x = 3;
        print(x);
    }

    結果はこんな感じ。

    1
    2
    3
    
    2
    undefined
    3

注意点として、ブロックスコープはありません。
例えば、以下。

1
2
3
4
5
6
7
8
9
10
11
//グローバル変数
var X = 5;
 
//ブロックスコープを期待してこう書く
{
var X = 3; 
print(x);
}
 
//これに5が入ってることを期待すると間違う
print(x);

結果はどちらも3が入ってます。

1
2
3
3

ブロックスコープがないので、
実際はグローバル変数を使い回しているんです。

実はJavaScriptの独自拡張にブロックスコープが使える「let」というのがあるらしいのですが、私は使っていません。なんかややこしくなりそうで^^;

もうひとつオマケ。
JavaScriptの関数は入れ子に宣言できます。
そのとき、内側の関数内で参照している変数が見つからなければ、
そのひとつ外側の関数に向かって変数名を探しにいきます♪
でもって、最終的にグローバル変数を参照することになりますね〜。

関連記事

  1. obj_clear.jpg

    JavaScript

    配列に入れた無名オブジェクトの値をクリアする

    オブジェクトの値を配列にいれて管理することってけっこうあります。…

  2. js_style.jpg

    JavaScript

    CSSのプロパティをJavaScriptで指定する

    Elementオブジェクトのstyleプロパティでその要素に対し…

  3. canvas.jpg

    JavaScript

    WebアプリでCanvasを使うための指定方法

    Webアプリをデザインするときのお決まりになりつつあるHTML5の…

  4. tweenmax_license01.jpg

    JavaScript

    「TweenMax.js」をビジネス利用のためのライセンス購入方法

    いつもJavaScriptのアニメーション部分でお世話になってる「…

  5. js_global.jpg

    JavaScript

    JavaScriptでグローバル変数を減らす方法

    グローバル変数はいいことない!もしかしたら使っているライブラリー…

  6. tweenmax_js_totation.jpg

    JavaScript

    【TweenMax.js】回転アニメーションも楽々!

    以前も記事に書いたアニメーション用のJavaScriptライブラリ…

最近の記事

  1. 【無印良品】ゴールデンウィーク中のご飯にレトルト買い込み!
  2. 世代ど真ん中だった!!『週刊少年ジャンプ展 vol2』
  3. デジタル通貨を買ってみた記録!とりあえず元は取っている!
  4. 【コレクション】カードダス:SDガンダム外伝シリーズ
  5. 【無印良品】作り置きに欠かせない!バルブ付き密閉保存容器
  6. 【UNIQLO】冬のジム通いにブロックテックフリースパーカをお得に購入!!
  7. 【UNIQLO】冬のジム通いにブロックテックフリースパンツをお得に購入!!
  8. 【UNIQLO】ユニクロ誕生感謝祭で買いだめ!
  9. 便利すぎる!買ってよかったキッチンツール「キッチンペーパーハンガー」
  10. ジムで活躍!プロテイン用のボトルにおすすめ!「nalgene(ナルゲン)の沖倉商店コラボ・ボトル」

アーカイブ

  1. 日常

    「紙の新しいコミュニケーションとデザインの可能性」
  2. Evernoteプレミアムをできるかぎり安く利用する方法!

    サービス

    Evernoteプレミアムをできるかぎり安く利用する方法!
  3. 一押しのiPhone用保護フィルム!パワーサポートの「アンチグレアフィルム」

    iPhone

    一押しのiPhone用保護フィルム!パワーサポートの「アンチグレアフィルム」
  4. オフィスで使いたいデザイン加湿器!BRUNO「TULIP STICK 2」

    プロダクト

    オフィスで使いたいデザイン加湿器!BRUNO「TULIP STICK 2」
  5. 日常

    闘いでした
PAGE TOP