var a=function(){}和function a(){}有什么区别

来源:8-3 计时器setInterval()

榎目贵音

2016-03-30 20:35

function b(){

document.write("aa");

}

var a=function(){

document.write("123");

}


b();

a();



好像没什么区别

写回答 关注

4回答

  • Joeh
    2016-03-30 21:31:07
    已采纳

    b();

    a();

    function b(){

    document.write("aa");

    }

    var a=function(){

    document.write("123");

    }

    这样再运行一下就有区别了

    function b(){} 为函数声明,程序运行前就已存在;var a = function(){} 为函数表达式,属于按顺序执行,所以a为undefined


    榎目贵音

    非常感谢!简单易懂!

    2016-03-30 21:42:24

    共 1 条回复 >

  • Keeln
    2016-08-17 17:03:11

    我刚就遇到这个问题,function a(){}属于封装函数,这个可以写在调用之后,但是var a = function (){}; 这个就必须写在调用a之前

  • 按照自己的节奏前行
    2016-03-30 21:08:18

    简单的说就是定义一个变量,把函数体传给变量;就像无论你用var a 还是 a都能被识别一样,个人观点

  • 微笑的鱼儿啦
    2016-03-30 20:57:49

    var a = function() {

      函数体:

      }:

    此时函数体本身作为变量存在,因此在浏览器进行执行前处理时并不把他加载在window对象的属性中,而是在程序执行过程中执行到变量赋值时才加载到window对象的属性中。

    function a () {}

    程序执行:按照从上到下的顺序执行,

      一旦用到变量,则变量名存入到堆内存,变量值存入到栈内存,此时内存回收程序员是无法控制的,只能等待浏览器回收。

      一旦执行函数,函数进入到栈内存中,函数的变量被加载到栈内存中,函数执行后,马上释放栈内存。


JavaScript进阶篇

本课程从如何插入JS代码开始,带您进入网页动态交互世界

468194 学习 · 21891 问题

查看课程

相似问题