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

首頁 > 編程 > JavaScript > 正文

javascript嵌套函數和在函數內調用外部函數的區別分析

2019-11-20 10:39:16
字體:
來源:轉載
供稿:網友

我們都知道在函數中定義的局部變量在聲明他的函數體以及其嵌套的函數內始終是有定義的,并且在函數的作用域鏈上始終會有個對象指向全局對象,使函數能夠訪問到全局變量。

var ga = 'global';var func = function() {  var la = 'local'; return function() {    return function()    {      return function()      {        alert(la);alert(ga);      }    } }}a = func();a()()();// 彈出 local 和 global

那么在外部定義的函數A, 被函數B在函數體內調用時,A能訪問到B中定義的局部變量嗎?答案是否定的,把上面的例子稍作修改如下

var ga = 'global';function repeat() { alert(la);  }var func = function() {  var la = 'local';  alert(1);  repeat();  alert(2);};func();

上面的運行結果是只彈出了1,在調用repeat的時候,因為訪問了未定義變量js解釋器就報錯把程序中斷了。

原因是函數在定義時保存了一個作用域鏈,repeat函數在外部定義,在他的作用域中并沒有一個局部變量叫la,繼續在全局作用域查找也沒找到la所以就會報錯。

所以嵌套函數和在函數內嵌套調用外部函數還是有很大區別的。

昨天在回答一個問題//m.survivalescaperooms.com/article/78958.htm時引發的思考,雖然概念我明白,但是當時一直想在函數內部調用的repeat為什么訪問不到調用他的函數的局部變量,今天又翻了下參考資料自己用代碼測試了一遍。希望這篇文章能幫助到有同樣困惑的朋友。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 洱源县| 苍南县| 闻喜县| 华亭县| 博罗县| 永登县| 新野县| 四子王旗| 乌鲁木齐县| 凉山| 香河县| 朝阳区| 通辽市| 台山市| 大冶市| 岐山县| 琼海市| 株洲县| 营山县| 广元市| 西华县| 乌鲁木齐县| 紫金县| 微山县| 拜泉县| 望江县| 高雄县| 全南县| 四会市| 勐海县| 玛纳斯县| 手游| 邻水| 皮山县| 万荣县| 乌苏市| 区。| 黄龙县| 通化市| 天全县| 安阳市|