JavaScript類和繼承 this屬性使用說明

來源:互聯網
上載者:User

this屬性工作表示當前對象,如果在全域作用範圍內使用this,則指代當前頁面對象window; 如果在函數中使用this,則this指代什麼是根據運行時此函數在什麼對象上被調用。 我們還可以使用apply和call兩個全域方法來改變函數中this的具體指向。
先看一個在全域作用範圍內使用this的例子: 複製代碼 代碼如下:<script type="text/javascript">
console.log(this === window); // true
console.log(window.alert === this.alert); // true
console.log(this.parseInt("021", 10)); // 10
</script>

函數中的this屬性是在運行時決定的,而不是函數定義時,如下: 複製代碼 代碼如下:// 定義一個全域函數
function foo() {
console.log(this.fruit);
}
// 定義一個全域變數,等價於window.fruit = "apple";
var fruit = "apple";
// 此時函數foo中this指向window對象
// 這種調用方式和window.foo();是完全等價的
foo(); // "apple"
// 自訂一個對象,並將此對象的屬性foo指向全域函數foo
var pack = {
fruit: "orange",
foo: foo
};
// 此時函數foo中this指向window.pack對象
pack.foo(); // "orange"

全域函數apply和call可以用來改變函數中this屬性的指向,如下: 複製代碼 代碼如下:// 定義一個全域函數
function foo() {
console.log(this.fruit);
}
// 定義一個全域變數
var fruit = "apple";
// 自訂一個對象
var pack = {
fruit: "orange"
};
// 等價於window.foo();
foo.apply(window); // "apple"
// 此時foo中的this === pack
foo.apply(pack); // "orange"

註:apply和call兩個函數的作用相同,唯一的區別是兩個函數的參數定義不同。
因為在JavaScript中函數也是對象,所以我們可以看到如下有趣的例子: 複製代碼 代碼如下:// 定義一個全域函數
function foo() {
if (this === window) {
console.log("this is window.");
}
}
// 函數foo也是對象,所以可以定義foo的屬性boo為一個函數
foo.boo = function() {
if (this === foo) {
console.log("this is foo.");
} else if (this === window) {
console.log("this is window.");
}
};
// 等價於window.foo();
foo(); // this is window.
// 可以看到函數中this的指向調用函數的對象
foo.boo(); // this is foo.
// 使用apply改變函數中this的指向
foo.boo.apply(window); // this is window.

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.