JS中var声明与function声明以及构造函数声明方式的区别

 

JS中常见的三种函数声明(statement)方式有这三种:express

// 函数表达式(function expression) 
var h = function () {
      // h
}

// 函数声明(function declaration) 
function h() {
      // h
}
// 构造函数(function constructor)
function H() {
    // H 
}

 

先说三者的显著区别:函数

第一种声明方式也就是var声明方式,函数表达式,又叫作函数字面量(Function Literals)、函数直接量(Function direct quantity), 函数只有在var语句声明以后才能被调用spa

第二种声明方式也就是function声明方式,函数能够在function声明以前被调用.net

第三种声明方式也就是构造函数声明方式,函数能够在function声明以前被调用,不一样于函数声明的是构造函数的函数名首字母要大写code

由于在函数预编译过程当中,会将函数声明总体提高,而对于var变量只会把var h进行提高,而后再在代码运行阶段进行赋值对象

对第一种状况,函数表达式是在函数运行阶段才赋值给变量hblog

对第二种状况,函数声明是在代码运行阶段以前,也就是代码解析阶段才赋值给标识符h原型链

对第三种状况,构造函数也是在代码运行阶段以前,也就是代码解析阶段才赋值给标识符H作用域

为了证实这种说法能够看下面两个例子:原型

对应第一种状况,

console.log(h)  // undefined
var h = function () {
      // h
}

console.log(h)  // function () {//h}
    
h = function () {
      // h1
}

console的结果是

undefined

ƒunction () {   // h }

由于赋值发生在代码运行阶段, 代码自上而下运行console.log(h)所在位置只能获取它以前的赋值

对应第二种状况,第三种状况,

console.log(h)  // function h() {//h}
function h() {
      // h
}

console.log(h)  // function h() {//h}
function h() {  
    // h1

}

console的结果是

ƒunction h() {
     // h1
}
ƒunction h() {
     // h1
}

由于赋值发生在代码解析阶段,代码运行到console.log(h)时解析早已完成, 而解析的结果是后面那个函数h,故会打印此结果

深刻:

JS声明函数的三种方式:

1. 函数表达式: 即上面第一种方式,这种方法使用function操做符建立函数,表达式能够存储在变量或者对象属性里。函数表达式每每被称为

匿名函数,由于它没有名字。证实这一点你能够 console.log(h.name); 能够看到打印为空 "",而h只是对函数的引用,不是函数名。

2. 函数声明: 即上面第二种方式,会声明一个具名函数,且函数能在其所在做用域的任意位置被调用,其建立的函数为具名函数,证实这一

点你能够 console.log(h.name); 能够看到打印为 "h"。 可在后面的代码中将此函数经过函数名赋值给变量或者对象属性

3. 构造函数function Fun(){}:不推荐这种用法,容易出问题,一般用于原型链中

 

深刻了解函数字面量和函数直接量:

https://blog.csdn.net/qq_25178609/article/details/51669870  https://blog.csdn.net/superhoy/article/details/52946157

相关文章
相关标签/搜索