榎目贵音
2016-03-30 20:35
function b(){
document.write("aa");
}
var a=function(){
document.write("123");
}
b();
a();
好像没什么区别
b();
a();
function b(){
document.write("aa");
}
var a=function(){
document.write("123");
}
这样再运行一下就有区别了
function b(){} 为函数声明,程序运行前就已存在;var a = function(){} 为函数表达式,属于按顺序执行,所以a为undefined
我刚就遇到这个问题,function a(){}属于封装函数,这个可以写在调用之后,但是var a = function (){}; 这个就必须写在调用a之前
简单的说就是定义一个变量,把函数体传给变量;就像无论你用var a 还是 a都能被识别一样,个人观点
var a = function() {
函数体:
}:
此时函数体本身作为变量存在,因此在浏览器进行执行前处理时并不把他加载在window对象的属性中,而是在程序执行过程中执行到变量赋值时才加载到window对象的属性中。
function a () {}
程序执行:按照从上到下的顺序执行,
一旦用到变量,则变量名存入到堆内存,变量值存入到栈内存,此时内存回收程序员是无法控制的,只能等待浏览器回收。
一旦执行函数,函数进入到栈内存中,函数的变量被加载到栈内存中,函数执行后,马上释放栈内存。
JavaScript进阶篇
468061 学习 · 21891 问题
相似问题