ホームページ >ウェブフロントエンド >jsチュートリアル >JS でのこの変数の簡単な説明
JavaScript では、この変数は非常に強力です。この記事では、JavaScript でのこれの使用方法について詳しく説明します。興味のある方は、
JavaScript の使用方法を参照してください。これは JavaScript のとらえどころのないキーワードであり、これに関する知識を完全に理解すると、オブジェクト指向
JavaScript プログラムを簡単に作成できるようになります。
この変数について最も重要なことは、これがどのオブジェクトを参照しているのかを明確にできることです。多くの情報には独自の説明があるかもしれませんが、一部の概念は少し複雑です。私の理解は次のとおりです。まず、this が配置されている関数がメソッドとして呼び出されるオブジェクトを分析し、次にそのオブジェクトが this によって参照されるオブジェクトです。
例1、
コードは次のとおりです:
var obj = {}; obj.x = 100; obj.y = function(){ alert( this.x ); }; obj.y(); //弹出 100このコードは非常に理解しやすいですが、obj.y()が実行されると、オブジェクトobjのメソッドとして関数が呼び出されます。関数本体は obj オブジェクトを指しているため、100 がポップアップ表示されます。 例 2、
コードは次のとおりです:
var checkThis = function(){ alert( this.x); }; var x = 'this is a property of window'; var obj = {}; obj.x = 100; obj.y = function(){ alert( this.x ); }; obj.y(); //弹出 100 checkThis(); //弹出 'this is a property of window'なぜここで「これはウィンドウのプロパティです」というメッセージが表示されるのか、少しわかりにくいかもしれません。 JavaScriptの変数スコープには「グローバル変数は
ウィンドウオブジェクト
のプロパティである」というルールがあります。 checkThis()を実行すると、window.checkThis()と等価になります。 したがって、このときcheckThis関数のthisキーワードの箇所がwindowオブジェクトとなり、windowオブジェクトが別のx属性('thisis)を持っていることになります。 「ウィンドウのプロパティ」)、「これはウィンドウのプロパティです」がポップアップ表示されます。上記の 2 つの例は、現在の関数がどのオブジェクトをメソッドとして呼び出すか (どのオブジェクトによって呼び出されるか) さえ分かれば、現在の this 変数のポイントを簡単に決定できるため、比較的理解しやすいです。
this.x と apply()、call()
call と apply を通じて、関数
の実行環境、つまり、一部のアプリケーションで非常に一般的に使用される this のポイントを再定義できます。
例 3: call()
コードは次のとおりです:
function changeStyle( type , value ){ this.style[ type ] = value; } var one = document.getElementByIdx( 'one' ); changeStyle.call( one , 'fontSize' , '100px' ); changeStyle('fontSize' , '300px'); //出现错误,因为此时changeStyle中this引用的是window对象,而window并无style属性。
例 4: apply()
コードは次のとおりです:
function changeStyle( type , value ){ this.style[ type ] = value; } var one = document.getElementByIdx( 'one' ); changeStyle.apply( one , ['fontSize' , '100px' ]); changeStyle('fontSize' , '300px'); //出现错误,原因同示例三
例5:
コードは次のとおりです:
var obj = { x : 100, y : function(){ setTimeout( function(){ alert(this.x); } //这里的this指向的是window对象,并不是我们期待的obj,所以会弹出undefined , 2000); } }; obj.y();
var obj = { x : 100, y : function(){ var that = this; setTimeout( function(){ alert(that.x); } , 2000); } }; obj.y(); //弹出100
var one = document.getElementByIdx( 'one' ); one.onclick = function(){ alert( this.innerHTML ); //this指向的是one元素,这点十分简单.. };
これは js のキーワードであり、関数がさまざまな状況で使用されると、この値は変わります。ただし、常に原則があり、これは関数を呼び出すオブジェクトを参照します。
1. 純粋な関数呼び出し。
コードは次のとおりです:
function test() { this.x = 1; alert(x); } test();
var x = 1; function test() { alert(this.x); } test();//1 var x = 1; function test() { this.x = 0; } test(); alert(x);//0
function test() { alert(this.x); } var o = {}; o.x = 1; o.m = test; o.m(); //1
コンストラクター
として呼び出されます。いわゆるコンストラクター関数は、新しいオブジェクトを生成することです。このとき、this はこのオブジェクトを指します。function test() { this.x = 1; } var o = new test(); alert(o.x);//1
コードは次のとおりです:
var x = 0; function test() { alert(this.x); } var o = {}; o.x = 1; o.m = test; o.m.apply(); //0 o.m.apply(o);//1
以上がJS でのこの変数の簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。