JavaScript 预编译

JavaScript 执行的原理

  • 函数声明整体提升 (提升到代码最前面)
  • 一个变量被声明后,变量声明提升(提升到代码最前面)
  • 同时声明变量和函数,那么函数会在变量声明的后面 (变量声明比函数声明先执行)

JavaScript 的全局预编译

console.log(变量);//undefined
var 变量 = 123;
function 函数(){
    console.log(函数);
}
函数()  //f{}
  1. 先创建window对象
	window{
	
	}
  1. 变量名提升 (在运行到console的前 就会先声明一个名为“变量”的变量 并且默认这个变量值为undefined)
	window{
	变量:undefined
	}
  1. 找到函数名
	window{
	变量:undefined
	函数:undefined
	}
  1. 把整个函数赋值给函数名
	window{
	变量:undefined
	函数:整个函数体
	}

ps(已经被提升过的执行时就不看了)

JavaScript 的函数预编译

a(1);         //1为实参
function a (a){  // 括号的a为形参
	console.log(a);
	function a(){}
	var a = 123;
	console.log(a)//123
}

(基本和全局预编译基本一致 就是在多了一步将实参赋值给形参)

  1. 先创建局部对象(局部为GO)
	GO{
	
	}
  1. 变量名提升 (在运行到console的前 就会先声明一个名为“变量”的变量 并且默认这个变量值为undefined)
	GO{
	a:undefined
	}
  1. 将实参给形参
	GO{
	a:1
	}
  1. 找到函数名
	GO{
	a:1 
	}
  1. 把整个函数赋值给函数名
	GO{
	a:整个函数体
	}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值