萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> js中this用法實例詳解

js中this用法實例詳解

 1. 指向window

全局變量

1 alert(this) //返回 [object Window]

全局函數

1 2 3 4 function sayHello(){ alert(this); } sayHello();

2. 指向該對象(在全局裡面this指向window,在某個對象裡面this指向該對象,在閉包裡面this指向window)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 var user="the Window"; var box={ user:'the box', getThis:function(){ return this.user; }, getThis2:function(){ return function (){ return this.user; } } }; alert(this.user);//the Window alert(box.getThis());//the box alert(box.getThis2()()); //the Window (由於使用了閉包,這裡的this指向window) alert(box.getThis2().call(box)); //the box 對象冒充(這裡的this指向box對象)

3. 用apply,call改變函數的this指向

1 2 3 4 5 6 7 8 function sum(num1, num2){ return num1+num2; } function box(num1, num2){ return sum.apply(this, [num1, num2]); //this 表示window的作用域 box冒充sum來執行 } console.log(box(10,10)); //20

4. new 對象

1 2 3 4 function Person(){ console.log(this) //將 this 指向一個新建的空對象 } var p = new Person();
copyright © 萬盛學電腦網 all rights reserved