JavaScript预解析

本文探讨了JavaScript中变量声明提升、作用域规则及函数执行顺序的问题。通过具体示例展示了变量提升现象、函数声明与表达式的区别以及执行上下文的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.易错:

f1();
console.log(c); 
console.log(b); 
console.log(a); 
function f1() {
	//相当于var a = 9; b = 9; c = 9; b和c直接赋值,没有声明,当全局变量看
	//易混淆:集体声明 var a = 9, b = 9, c = 9;
	var a = b = c = 9; 
	console.log(a); 
	console.log(b); 
	console.log(c);
}

执行顺序:

function f1() {
	var a;
	a = b = c = 9; 
	console.log(a); 
	console.log(b); 
	console.log(c);
}
f1();
console.log(c); 
console.log(b); 
console.log(a); 

执行结果:
在这里插入图片描述

2.比较

2.1

fn();
function fn() {
	console.log('打印');
}

执行顺序:

function fn() {
	console.log('打印');
}
fn();

执行结果:
在这里插入图片描述

2.2

fn();
var fn = function() {
	console.log('想不到吧');
}

执行顺序:

var fn;
fn();
var fn = function() {
	console.log('想不到吧');
}

执行结果:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值