鍍金池/ 問(wèn)答/HTML5  HTML/ JavaScript函數(shù)體內(nèi)的變量聲明問(wèn)題

JavaScript函數(shù)體內(nèi)的變量聲明問(wèn)題

圖片描述

分別執(zhí)行上面的兩個(gè)函數(shù),F1不會(huì)報(bào)錯(cuò),F2報(bào)錯(cuò)提示變量重復(fù)。
如果函數(shù)的參數(shù)a是以let a的形式聲明的,那么函數(shù)體內(nèi)無(wú)論是var a還是let a都應(yīng)該是重復(fù)聲明變量的啊,難道不是都應(yīng)該會(huì)報(bào)錯(cuò)的嗎?為什么只有F1報(bào)錯(cuò)呢?
求大神指導(dǎo)~

回答
編輯回答
青裙
2018年6月16日 18:04
編輯回答
終相守

我覺(jué)得這個(gè)問(wèn)題,有3點(diǎn):

1.函數(shù)作用域
2.函數(shù)參數(shù)屬于局部變量
3.let 不能重復(fù)申明

其實(shí)和函數(shù)F(1)無(wú)關(guān)  
function F2(a){
    let a =456;
}
F2(1)

單單這個(gè)函數(shù)你就報(bào)錯(cuò)了,原因是:函數(shù)的參數(shù)是屬于局部變量,作用域和let 申明的變量 是一樣的 ,let 不允許在同一個(gè)作用域下重復(fù)聲明,所以就報(bào)這個(gè)錯(cuò)啊,var是可以重復(fù)聲明的

其實(shí)這也得出一個(gè)結(jié)論:函數(shù)的參數(shù)是js 內(nèi)部聲明過(guò)的,其實(shí)就和js的默認(rèn)參數(shù)一樣的道理

2017年12月20日 05:49
編輯回答
澐染

用let聲明變量:在相同的函數(shù)或塊作用域內(nèi)重新聲明同一個(gè)變量會(huì)引發(fā)SyntaxError;而var不會(huì)。
這是let與var在聲明變量方面的一個(gè)區(qū)別之一。

2018年7月15日 04:27
編輯回答
風(fēng)畔

首先說(shuō)
“如果函數(shù)的參數(shù)a是以let a的形式聲明的,” 這里你傳遞的參數(shù)并沒(méi)有通過(guò)let聲明;
再說(shuō)
就算你傳遞的參數(shù)是通過(guò)let聲明的,聲明是在這個(gè)函數(shù)執(zhí)行的作用域外,也不影響函數(shù)內(nèi)部的let聲明;

之所有前面不報(bào)錯(cuò)是因?yàn)閰?shù)本質(zhì)上就是函數(shù)內(nèi)部的一個(gè)var 聲明對(duì)象,所以再次var 聲明覆蓋是沒(méi)有問(wèn)題的。
let聲明則不允許覆蓋前面的同名聲明

2017年11月2日 03:41
編輯回答
柚稚

首先,function() 這個(gè)()里的a是一個(gè)私有常量。區(qū)別于下面被定義的 a (如 var a);
其次,我說(shuō)的可能不太專業(yè),var可以重新定義一個(gè)變量,而let不行。(如 var x = 1;var x = 3;但是你不能let x = 1;let x = 3;塊級(jí)中,let只能一次。)
最后,我給你分析下你的函數(shù) 執(zhí)行 流程: var window.a = 123;

                                let window.a = 123;//window.a已經(jīng)被定義,所以報(bào)錯(cuò)。
                                
                                
2018年5月14日 18:02
編輯回答
晚風(fēng)眠
function F1(a){
    var a=123;
}

function F2(a){
    let a=123;
}

F1(1);
F2(1);

JS中函數(shù)聲明參數(shù)在運(yùn)行時(shí)會(huì)自動(dòng)創(chuàng)建一個(gè)函數(shù)體內(nèi)的變量,var聲明的變量允許重復(fù)聲明,而let聲明的變量是不允許重復(fù)聲明的,這里面包括通過(guò)var聲明的變量不能通過(guò)let再次聲明,通過(guò)let聲明的變量,var再次聲明也是不允許的,let聲明的也是如此

let p1=1;
var p1=10;//Uncaught SyntaxError: Identifier 'p1' has already been declared

var p2=1;
let p2=10;//Uncaught SyntaxError: Identifier 'p2' has already been declared

let p3=1;
let p3=10;//Uncaught SyntaxError: Identifier 'p3' has already been declared
2018年8月6日 10:46