美文网首页
JavaScript(js)函数声明与函数表达式的区别

JavaScript(js)函数声明与函数表达式的区别

作者: 全栈学习笔记 | 来源:发表于2020-02-25 19:52 被阅读0次

在JavaScript中,函数是经常用到的,在实际开发的时候,我想很多人都没有太在意函数的声明与函数表达式的区别,但是呢,这种细节的东西对于学好js是非常重要的。

函数声明与函数表达式用代码写出来是这样的:

//函数声明

function say(){

    console.log("函数声明")

}

//函数表达式

var say1 = function(){

    console.log("函数表达式")

}

那我们来看看,这两种方式到底有什么不同呢?

首先,在函数调用方面,看下面的代码

say();

//函数声明

function say(){

    console.log("函数声明")

}

这样的执行结果是什么呢?答案是打印出“函数声明”,那你看下面的代码

say1();

//函数声明

function say(){

    console.log("函数声明")

}

//函数表达式

var say1 = function(){

    console.log("函数表达式")

}

这样的执行结果是什么呢?注意,我们是调用的函数表达式,这样的结果是会报错,为什么呢?

一起来看看,首先我们先说第一种,函数声明的调用,函数声明的调用这个其实不用讲你就知道,函数声明了嘛,哪里都可以调用的(function会有预解析,预解析之后函数就存在了,所以那里都能调用它了)。至于下面这种函数表达式,为什么在函数表达式上面执行会报错呢?来看看下面的代码

console.log(a)

var a=1;

这段代码的执行结果是什么呢?undefined,这是不是很像我们的函数表达式了,其实,如果说我们在函数表达式之前也打印一下这个say1(),结果也是undefined,原因就是带有var 的变量,当然这里说的是全局变量,它在预解析的时候会有一个变量提升,变量提升是什么意思呢,看上面这段代码,其实就相当于下面这段代码

var a;

console.log(a);

a=1;

现在知道了吧,a这个变量是存在的,并且初始化成了一个undefined,所以说我们的函数表达式也是一样的,它也有变量提升,在将函数赋值给你定义的变量之前,调用就会报它不是函数的错,而打印出来就是undefined,是不是很好理解呢,学到了吗?

如果你觉得对你有帮助的话,记得点个关注哦,我会持续更新更多你想知道的,谢谢!

相关文章

  • 函数与作用域

    1.函数声明和函数表达式有什么区别?Javascript 中函数声明和函数表达式是存在区别的,函数声明在JS解析时...

  • javascript函数声明与函数表达式的区别

    javascript 函数声明与函数表达式的区别 就一点,函数声明有函数声明提升效果,可以在定义之前就引用,而函数...

  • 函数声明之函数提升

    Javascript 中函数声明和函数表达式是存在区别的,函数声明在JS解析时进行函数提升,因此在同一个作用域内,...

  • level-17

    函数声明和函数表达式有什么区别 (*) 在javascript中,函数有两种定义写法,函数定义表达式和函数声明,其...

  • js函数

    函数声明和函数表达式有什么区别 函数声明: 函数表达式: JavaScript 解释器中存在一种变量声明被提升的机...

  • JS函数与作用域

    函数声明和函数表达式有什么区别 JavaScript 中需要创建函数的话,有两种方法:函数声明、函数表达式,各自写...

  • JavaScript函数与作用域

    函数声明和函数表达式的区别 JavaScript 中创建一个函数,主要有两种方法:函数声明、函数表达式,各自写法如...

  • 函数

    函数声明和函数表达式有什么区别 函数声明 函数表达式 函数声明和函数表达式的区别: 函数声明必须给定函数名称,函数...

  • js 任务 3

    1函数声明和函数表达式有什么区别 在javascript中,函数有两种定义写法,函数定义表达式和函数声明,其例子分...

  • 函数

    一、问答 函数声明和函数表达式有什么区别? Js中的函数声明是指下面的形式: 函数表达式则是类似表达式那样来声明一...

网友评论

      本文标题:JavaScript(js)函数声明与函数表达式的区别

      本文链接:https://www.haomeiwen.com/subject/glwfchtx.html