亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

javascript - 函數設置參數默認值的問題

瀏覽:103日期:2023-04-10 17:32:22

問題描述

var x = 1; function foo(x,y=function(){x=2;}){ var x = 3; y(); console.log(x); }foo();

這段代碼出現在阮一峰老師寫的es6那本書,最后輸出3,文字說明說y中的x和var x = 3;的x不是同一個x,這兒有點不理解。然后把var x= 3 的var去掉,就能輸出2,更不理解了。。。希望能有解答

問題解答

回答1:

這里其實是涉及到 ES6 默認參數引入的一個中間作用域。這個問題當初阮一峰也弄錯過,當然這里是正確的。

中間作用域的目的就是防止默認參數被函數里面的變量污染。默認參數本意是為了讓參數有默認值,假如函數內部的變量還能提升上來,那么默認參數就沒意義了。具體的解釋和例子可以看文章。

所以看回問題,

var x = 1; function foo (x2, y = function () { x = 2; }) { var x = 3; y(); console.log(x); }foo();

這里有三個作用域,把 x 由外到里標記出來就是:

var x1 = 1; function foo (x2, y = function () { x2 = 2; console.log(x2); }) { var x3 = 3; y(); console.log(x3); }foo();console.log(x1);

假如沒有了參數的 x,那么標記出來就是:

var x1 = 1; function foo (y = function () { x1 = 2; console.log(x1); }) { var x2 = 3; y(); console.log(x2); }foo();console.log(x1);回答2:

y()修改的是foo函數的參數x,并非全局x。(這里你可以在y()調用后,console.log(x),可發現全局x還是1.) 問題就簡單了: 1) 當用var x = 3時,foo里面的console.log(x)打印的就是foo里的局部變量x,y()修改的只是參數x,所以最終輸出是局部變量x = 32)當不用var時,foo里的所有x都指向參數x,而用y()把參數x修改為2,最終輸出2

回答3:

y 的默認值改變的是全局變量的x;把var x= 3 的var去掉,就能輸出2 是因為在foo的作用域內找不到x,所以在往上尋找,找到全局變量x,此時已被賦值為2

回答4:

這是局部變量和全局變量生命周期的區別,方法里面的var x = 3;是局部變量,兩個變量同名,方法體里面會使用局部變量,不會使用全局變量,所以輸出的是var x = 3;這個x的值;當你去掉var x = 3;的var,說明在方法里面沒有另外定義局部變量,使用的是全局變量x,而你方法參數又把這個全局變量值修改為2,所以輸出為2;

回答5:

首先你要理解var操作符的定義,用var操作符定義的變量將成為定義該變量的作用域中的局部變量,也就是說,如果在函數中使用var定義一個變量,那么這個變量屬于函數的一個局部變量,在函數退出時即被銷毀,而不使用var直接定義的變量都將成為全局變量。另一個你要理解的概念是作用域鏈的問題,程序查找一個變量時,首先會在當前作用域內查找,若沒有找到則順著作用域鏈依次向上查找,遍歷完都沒有則報undefined。回到上面的代碼,首先在全局作用域中利用var定義 x=1; x 即屬于全局變量,接下來在函數foo內部定義了局部變量var x=3;X就屬于函數的局部變量,接著執行y函數,對全局變量x進行修改賦值,這時x變為2,記住此時修改的是全局變量x而不是局部變量X,接下來打印x時,函數會依據作用域鏈先在函數內部查找x的值,找到x=3后即輸出值,所以結果為3,若把var x=3的var去掉,則x變為全局變量,修改x就如同y函數中x賦值一樣,這時只存在一個全局變量x,按照代碼執行順序,內部先修改全局變量X為3,然后y函數修改全局變量x為2,打印時,順著作用域鏈,在函數內部沒有找到x值,則接著在全局作用域中查找,此時X為2,所以結果為2

回答6:

var x = 1;function foo(x, y = function () { x = 2; }) { var x = 3; eval(`(${y.toString()})()`); console.log(x);}foo();回答7:

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 欧美最大成人毛片视频网站 | 国产精品久久一区二区三区 | 1024手机在线播放 | 免费又爽又黄的禁片1000部 | 国产精品一区二区在线观看 | 妞干网免费观看视频 | 国产精品丝袜 | 欧美成人免费在线视频 | 啪啪综合网 | 精品国内一区二区三区免费视频 | 91亚洲国产在人线播放午夜 | 国产jav | 尤物视频在线观看免费 | 91福利免费体验区观看区 | 久久久最新精品 | 外国三级毛片 | 欧美成年黄网站色高清视频 | 蜜桃臀久久伊人福利 | 免费中文字幕在线 | 久久香蕉精品视频 | 国产一区二区三区四区在线污 | 黄色三级视频在线观看 | 国产精品美女一区二区 | 黄 色 片成 人免费观看 | 亚洲精品在线播放视频 | 干成人网 | 成人αv在线视频高清 | 国产对白91色拍高清精品 | 国产精品久草 | 成人亚洲网 | 亚洲成色| 亚洲国产一区在线精选 | 一二三区乱码一区二区三区码 | seba51久久精品 | 黄色毛片免费在线观看 | 黄色小视频观看 | 免费看片在线 | 在线免费观看黄色片 | 国产乱通伦| 久久精品国产精品亚洲精品 | 亚洲欧美一区二区三区在饯 |