この記事では、JavaScript に関する関連情報を詳しく紹介します。
this の値は実行時に決定されます。プログラムが実行中であることは、状況に応じて次の状況に分類できます。
1. グローバル スコープの this グローバル スコープでは、this は window オブジェクトを指します。console.log(this);//指向window对象 this.x = 5//在全局作用域内创建一个x //与this.x = 5的等价情况: //var x = 5; //x = 5;
2.関数内のこれ
JSには直接呼び出される関数を通常の関数と呼び、newを通してオブジェクトを作成する関数をコンストラクターと呼びます。
2.1 コンストラクター内の This コンストラクター内の This は、作成するオブジェクトを指します。次のようなものです。function Person(name){ this.name = name;//this指向该函数创建的对象person } var person = new Person("chaimm");
上記の例で Perosn 関数が直接実行される場合、これはウィンドウ オブジェクトを表すため、関数の実行後にグローバル名が作成されます。
function Person(name){ this.name = name;//this指向window } Person("chai");//当作普通函数执行,this指向window对象
3. オブジェクト内の this
オブジェクト内の this は、次のような現在のオブジェクトを指します。
var person = { name : "chaimm", getName : function(){ return this.name; } }
var person = { name : "chaimm", setName : function(name){ (function(name){ this.name = name; //此时this并不代表person对象,而是代表window对象 })(name); } }
var person = { name : "chaimm", setName : function(name){ var thar = this;//将this赋给that (function(name){ that.name = name;//此时that指向person对象 })(name); } }
var person = { name : "chaimm", getName : function(){ return this.name; } } //将getName函数赋给一个新的变量 var newGetName = person.getName; //通过新的变量调用这个函数,这个函数中的this将指向window newGetName();//若全局作用域中没有name,则将返回undefined
4. 呼び出しを使用します。これら 2 つの関数は、呼び出された関数内の this が指すオブジェクトを手動で指定できます。
//定义一个构造函数 var Person = function(name){ this.name = ""; this.setName = function(name){ this.name = name; } } //创建两个对象 var personA = new Person("A"); var personB = new Person("B"); //使用personA的setName函数去修改personB的name属性 personA.setName.apply(personB,["C"]);
applyの使い方
オブジェクトA.関数名.apply(オブジェクトB,パラメータリスト);
オブジェクトBがapplyの最初のパラメータとして渡されると、オブジェクトAの関数内のthisはオブジェクトを指しますB、このとき、オブジェクト A に対するこの関数の操作はオブジェクト B に適用され、オブジェクト A を使用してオブジェクト B の関数を呼び出すことが実現されます。上記は私があなたのためにまとめたものです。
関連記事:JavaScript が何を指すのかについての詳細な紹介(写真と文章)
以上がJavaScriptの詳しい説明はこちら(グラフィックチュートリアル)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。