国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

JavaScript 中的 this 簡單規則

2024-05-06 15:26:29
字體:
來源:轉載
供稿:網友

幾條規則確定函數里的 this 是什么。

想確定 this 是什么其實非常簡單。總體的規則是,通過檢查它的調用位置,在函數被調用的的時候確定 this。它遵循下面這些規則,接下來以優先級順序說明。

規則

1、如果在調用函數時使用 new 關鍵字,那么函數里的 this 就是一個全新的對象。

function ConstructorExample() {  console.log(this);  this.value = 10;  console.log(this);}new ConstructorExample();// -> {}// -> { value: 10 }

2、如果使用 apply、call 或者 bind 調用函數,那么函數里的 this 就是作為參數傳進去的對象。

function fn() {  console.log(this);}var obj = {  value: 5};var boundFn = fn.bind(obj);boundFn();   // -> { value: 5 }fn.call(obj); // -> { value: 5 }fn.apply(obj); // -> { value: 5 }

3、如果函數作為一個方法調用,就是說如果使用點符號調用函數,那么 this 就是擁有這個函數作為屬性的對象。換句話說,當一個點在函數調用的左側時,this 就是這個點左側的那個對象。

var obj = {  value: 5,  printThis: function() {    console.log(this);  }};obj.printThis(); // -> { value: 5, printThis: ƒ }

4、如果函數作為一個純粹的函數調用,也就是說,它在沒有上述任何條件的情況下被調用,那么 this 就是全局對象。在瀏覽器里,就是 window 對象。

function fn() {  console.log(this);}// 如果在瀏覽器里調用:fn(); // -> Window {stop: ƒ, open: ƒ, alert: ƒ, ...}

注意這個規則其實和第三個規則是一樣的,區別在于沒有聲明為方法的函數會自動成為全局對象 window 的屬性。因此,這其實是一個隱式的方法調用。當我們調用 fn(),其實就會被瀏覽器理解為 window.fn(),所以 this 就是 window。

console.log(fn === window.fn); // -> true

5、如果上述規則有多個適用,那么優先級更高的就會設置 this 值。

6、如果是 ES2015 里的箭頭函數,那么它將忽略上述所有規則,并在創建的時候接收包含它的作用域作為 this 的值。想確定 this 具體是什么的話,只需從創建箭頭函數那里往上一行,看看那兒的 this 是什么,箭頭函數里的 this 值和它一樣。

const obj = {  value: 'abc',  createArrowFn: function() {    return () => console.log(this);  }};const arrowFn = obj.createArrowFn();arrowFn(); // -> { value: 'abc', createArrowFn: ƒ }

看回第三個規則,當我們調用 obj.createArrowFn() 的時候,createArrowFn 里的 this 是 obj,因為這是方法調用。因此,obj 會在 arrowFn 里綁定到 this 上。如果我們在全局作用域創建一個箭頭函數,那么 this 值就會是 window。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 南开区| 仁怀市| 泉州市| 灯塔市| 枣强县| 会东县| 周口市| 永和县| 固始县| 长治市| 云阳县| 新和县| 满城县| 襄汾县| 紫阳县| 资阳市| 东山县| 山丹县| 江北区| 定陶县| 宁化县| 辛集市| 江孜县| 鹿邑县| 文山县| 隆化县| 庐江县| 唐海县| 宣化县| 油尖旺区| 大冶市| 崇阳县| 天台县| 浦县| 宁津县| 连州市| 南靖县| 获嘉县| 洛隆县| 孟连| 凭祥市|