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

首頁 > 編程 > JavaScript > 正文

JS ES6中setTimeout函數的執行上下文示例

2019-11-19 16:43:06
字體:
來源:轉載
供稿:網友

本文介紹的是setTimeout函數,延遲執行函數里的執行上下文,分享給大家供大家參考學習,來看看詳細的內容:

(1)ES5中,setTimeout里面的函數的執行上下文為全局上下文,舉例來說:

function log(){ setTimeout(function(){console.log(this.id)},100)}var id=42log.call({id:21})//輸出的結果為42

我們可以看到setTimeout,被延遲執行的函數,里面的this,指向的是全局作用域,也就是這個函數的上下文為全局上下文。

(2)在ES6的箭頭函數中,setTimeout里面,如果執行了一個箭頭函數,那么這個函數的執行上下文為定義這個箭頭函數所在的函數。

function log(){ setTimeout(()=>{  console.log(this.id) },100)}var id=42;log.call({id:21})//這次輸出的是21

總結:

因為ES6中,箭頭函數的this,規定的指向定義這個箭頭函數所在的那個函數。于是這里箭頭函數里面的this,就固定bind了{id:21}。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 郯城县| 安阳县| 湘乡市| 广汉市| 武乡县| 巴中市| 光泽县| 龙州县| 渭源县| 大安市| 泰安市| 潮安县| 南岸区| 玉溪市| 隆回县| 高平市| 台州市| 响水县| 阳信县| 禄丰县| 贵溪市| 乌兰察布市| 禄丰县| 海晏县| 神农架林区| 崇阳县| 会宁县| 天长市| 饶平县| 老河口市| 紫金县| 景德镇市| 祁东县| 尤溪县| 蓝山县| 女性| 正蓝旗| 南宁市| 泾阳县| 兴化市| 宁国市|