JavaScript中一般变量、函数、函数参数重名时的覆盖优先级

在JavaScript中,当一般变量、函数、函数参数重名时,它们的优先级为:

已初始化的一般变量 > 函数 > 函数参数 > 未初始化的一般变量

下面是示例:

var a;
function a() {
    var b = 0;
}
 
//结果为function a() { var b = 0;},因为函数的优先级大于未初始化的一般变量
console.log(a);
 
var a = 1;
function a() {
    var b = 0;
}
 
//结果为1,因为已初始化的一般变量优先于函数
console.log(a);
function foo(a) {
    function a() {
        var b = 0;
    }
 
    //结果为function a(){var b=0;},因为函数的优先级大于重名的函数参数
    console.log(a);
}
foo(1);

规则是:
1、对于同名的变量声明,Javascript采用的是忽略原则,后声明的会被忽略,变量声明和赋值操作可以写在一起,但是只有声明会被提升,提升后变量的值默认为undefined,结果是在赋值操作执行前变量的值必为undefined

2、对于同名的函数声明,Javascript采用的是覆盖原则,先声明的会被覆盖,因为函数在声明时会指定函数的内容,所以同一作用域下一系列同名函数声明的最终结果是调用时函数的内容和最后一次函数声明相同

3、对于同名的函数声明和变量声明,采用的是忽略原则由于在提升时函数声明会提升到变量声明之前,变量声明一定会被忽略,所以结果是函数声明有效

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值