js变量提升

本质:只提升声明部分
例子

1.我是变量声明,我会被提升在作用域顶端!
var a;
2.我是变量定义,我的声明部分会被提升,赋值部分不会被提升!

var b = 'test';

3.我是函数定义,或者叫我函数表达式。其实我就是变量定义,只不过恰好被赋值的类型是函数,所以也只提升变量名,不提升函数值!

var c = function() {
    console.log('test');
}

4.我是函数声明,所以我全部被提升了,包括函数名和函数体。另外,我的优先级比变量声明要高,名字和我相同的变量声明会被忽略!

function d() {
    console.log('test');
}

题目

参数是引用参数

var foo={n:1};
(function (foo) {
    console.log(foo.n);
    foo.n=3;
    var foo={n:2};
    console.log(foo.n);
})(foo);
console.log(foo.n);

结果: 1 2 3
参数是传值参数

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

结果:1 2 1
解释:

var foo={n:"我是形参或全局变量"};
(function (foo) {
    console.log(foo.n);
    foo.n="我改变了参数和全局变量";
    var foo={n:"我是局部变量"};
    console.log(foo.n);
})(foo);
console.log(foo.n);

第一步:进行预编译,var全局变量foo、匿名函数 function、var局部变量foo
第二步:代码自上而下、自左向右执行计算:
对全局变量foo进行赋值foo={n:1};注意:此值为对象,属于引用类型;
匿名函数传入参数foo={n:1}自执行;
console.log(foo);打出数字1;
由于存在foo局部变量,那么对foo变量进行赋值foo={n:3},同时更改了引用类型的参数值,全局foo变量被重新赋值foo={n:3};
对局部变量foo进行重新赋值foo={n:2};
console.log(foo);打出数字2;
全局变量foo={n:3},因此,console.log(foo);打出数字3;

alert(undefined==null)        true
alert(undefined===null)      false
alert(null==undefined)        true
alert(null===undefined)      false
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值