国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - 函數(shù)設(shè)置參數(shù)默認(rèn)值的問題

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

問題描述

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

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

問題解答

回答1:

這里其實(shí)是涉及到 ES6 默認(rèn)參數(shù)引入的一個(gè)中間作用域。這個(gè)問題當(dāng)初阮一峰也弄錯(cuò)過,當(dāng)然這里是正確的。

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

所以看回問題,

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

這里有三個(gè)作用域,把 x 由外到里標(biāo)記出來就是:

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

假如沒有了參數(shù)的 x,那么標(biāo)記出來就是:

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函數(shù)的參數(shù)x,并非全局x。(這里你可以在y()調(diào)用后,console.log(x),可發(fā)現(xiàn)全局x還是1.) 問題就簡單了: 1) 當(dāng)用var x = 3時(shí),foo里面的console.log(x)打印的就是foo里的局部變量x,y()修改的只是參數(shù)x,所以最終輸出是局部變量x = 32)當(dāng)不用var時(shí),foo里的所有x都指向參數(shù)x,而用y()把參數(shù)x修改為2,最終輸出2

回答3:

y 的默認(rèn)值改變的是全局變量的x;把var x= 3 的var去掉,就能輸出2 是因?yàn)樵趂oo的作用域內(nèi)找不到x,所以在往上尋找,找到全局變量x,此時(shí)已被賦值為2

回答4:

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

回答5:

首先你要理解var操作符的定義,用var操作符定義的變量將成為定義該變量的作用域中的局部變量,也就是說,如果在函數(shù)中使用var定義一個(gè)變量,那么這個(gè)變量屬于函數(shù)的一個(gè)局部變量,在函數(shù)退出時(shí)即被銷毀,而不使用var直接定義的變量都將成為全局變量。另一個(gè)你要理解的概念是作用域鏈的問題,程序查找一個(gè)變量時(shí),首先會在當(dāng)前作用域內(nèi)查找,若沒有找到則順著作用域鏈依次向上查找,遍歷完都沒有則報(bào)undefined?;氐缴厦娴拇a,首先在全局作用域中利用var定義 x=1; x 即屬于全局變量,接下來在函數(shù)foo內(nèi)部定義了局部變量var x=3;X就屬于函數(shù)的局部變量,接著執(zhí)行y函數(shù),對全局變量x進(jìn)行修改賦值,這時(shí)x變?yōu)?,記住此時(shí)修改的是全局變量x而不是局部變量X,接下來打印x時(shí),函數(shù)會依據(jù)作用域鏈先在函數(shù)內(nèi)部查找x的值,找到x=3后即輸出值,所以結(jié)果為3,若把var x=3的var去掉,則x變?yōu)槿肿兞?,修改x就如同y函數(shù)中x賦值一樣,這時(shí)只存在一個(gè)全局變量x,按照代碼執(zhí)行順序,內(nèi)部先修改全局變量X為3,然后y函數(shù)修改全局變量x為2,打印時(shí),順著作用域鏈,在函數(shù)內(nèi)部沒有找到x值,則接著在全局作用域中查找,此時(shí)X為2,所以結(jié)果為2

回答6:

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

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 欧美ⅹxxxx视频 | 欧美激情伦妇在线观看 | 国产日韩在线观看视频 | 91视频18| 亚洲欧美日韩精品久久 | 日韩成人在线播放 | 欧美一级成人免费大片 | 国产在线观看成人 | 久久爽久久爽久久免费观看 | 久久 精品 一区二区 | 成人欧美精品久久久久影院 | 久草视频福利在线观看 | 高清国产一级精品毛片基地 | 久久看片网 | 免费在线观看亚洲 | 一级做a爰片久久毛片潮喷 一级做a爰片久久毛片美女 | 亚洲撸 | 亚洲黄色第一页 | 黄色免费在线网址 | 在线三级网址 | 国产午夜亚洲精品第一区 | 亚洲视频综合网 | 欧美一级鲁丝片 | 国产精品成人观看视频网站 | 国产国语对白一级毛片 | 成人网久久 | 久久99精品久久久久久h | 国产亚洲美女精品久久 | 国模偷拍在线观看免费视频 | 亚洲网站在线播放 | 国内美女福利视频在线观看网站 | 国产黄色小视频在线观看 | 一级毛片在线播放 | selaoban在线视频免费精品 | 日本欧美一区二区三区片 | 国产八区 | 中文字幕毛片 | 日本大臿亚洲香蕉大片 | 亚洲三级网址 | 国产精品影视 | 国内精品久久久久久中文字幕 |