JS声明提前

JS中的声明提前,变量声明提前,函数声明提前,以及声明提前的顺序

首先来看以下一段代码:

console.log(a)//?
a();//?
var a ;
function a(){
   console.log(10);
}
console.log(a);//?
a = 6;
a();//?

四个输出分别是什么呢?我们来调试一下,
执行到 a= 6时输出如下:
在这里插入图片描述
最后一个a();报错。
接下来我们来分析一下原因

一、什么是变量声明提前?

变量在声明它们的函数体以及这个函数体嵌套的任意函数体内始终可见。说直白点,在声明一个变量的前后,你都可以直接使用它,并不会报错。举个例子:

(function test() {
	console.log(name);
	var name = 'zhangsan';
	console.log(name);
})()

打印结果:
在这里插入图片描述
因为以上代码等同于

(function test() {
    var name
	console.log(name);
	name = 'zhangsan';
	console.log(name);
})()
2.什么是函数声明提前?

函数声明提前的原理与变量声明提前情况类似,需要提醒的是,只有函数声明格式的函数才会存在函数声明提前,比如函数表达式,构造函数,都不存在函数声明提前。

函数创建的三种写法:

a.函数声明:function fun(a){console.log(a)};(只有这个存在函数声明提前)

b.函数表达式:var fun = function(a){console.log(a)};

c.构造函数:var fun = new Function(“a”,console.log(a));

test()
function test() {
    console.log(1);
}

此代码等同于

function test() {
    console.log(1);
}
test()
再来看看函数表达式
test() //报错
console.log(test) //undefined
var test = function () {
	console.log(1);
}
test() //输出 1

这里的test被当做变量处理,相当于先声明一个变量,再将function赋值给这个变量就,即等同于:

var test 
test() //此时函数未声明 所以报错
console.log(test) //已声明 只是未赋值
test = function(){
	console.log(1)
}
test() //函数已声明 可以使用
3.变量提升的顺序

既然函数声明和变量声明都会提前,那么到底函数先提升还是变量先提升呢?
先来看一段简单的代码:

console.log(test)

function test() {
	console.log(1)
}
var test

为了公平起见我们把变量的位置和函数的位置换一下

console.log(test)
var test
function test() {
	console.log(1)
}

结果:
在这里插入图片描述
我们可以看到,两次打印的结果都是function,也就是说函数的声明提前会高于变量的声明提前。

最后让我们回到

console.log(a)//?
a();//?
var a ;
function a(){
   console.log(10);
}
console.log(a);//?
a = 6;
a();//?

此代码等同于:

function a(){
	console.log(10)
}
var a;
console.log(a); //funtion 因为函数的提前的优先级更高
a(); //函数已声明 所以输出是10
console.log(a); // function 这里和上一个一样 都是输出function
a = 6;
a(); //报错 因为 已经把6赋值了 a 了,此时a不再是函数
----------------------------- 最后再来看一个例子 ----------------------------

(学习的时候阴差阳错打出来的代码,想半天给不出解释,最后问老师才得以解决)

console.log(test()) //???
function test() {
 console.log('test')
}
var test

先来看看输出吧
在这里插入图片描述
这里很容易造成一个误区,执行test()时打印test,然后变成变成console.log(test)所以打印undefined???
前面说过了函数声明优先变量声明,打印结果不应该为function吗???
然后我们试着把 var test删除,

console.log(test()) //???
function test() {
 console.log('test')
}

打印结果却不变,所以问题肯定出在了函数上面。

其实很简单
test()运行的结果应该是函数的一个返回值,而console.log中打印的test并不是这个函数执行返回的结果,也就是说console.log(test())打印的应该是函数的返回值。

console.log(test()) 
function test() {
 console.log('test')
 return 111
}

在这里插入图片描述
而我们之前并没有这个返回值
我的理解是:函数体本身就声明了返回值 而我们并没有给这个返回值赋值,所以返回值是undefined。

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaScript函数是一种可重复使用的代码块,它可以接受输入参数并返回值。函数可以用来组织代码、减少重复代码、提高代码的可读性和可维护性。在JavaScript中,函数可以通过函数声明、函数表达式和箭头函数来定义。函数可以有任意数量的参数,也可以没有参数。函数可以返回任何类型的值,包括数字、字符串、布尔值、对象和函数等。函数可以在全局作用域或局部作用域中定义,也可以作为对象的方法来定义。在JavaScript中,函数是一等公民,可以作为参数传递给其他函数,也可以作为返回值返回给其他函数。 ### 回答2: JavaScript函数是一种非常重要的概念,它允许我们定义一段可重复使用的代码片段,同时还可以让我们更好的组织和管理程序的结构。在JavaScript中,函数可以作为一个值进行处理,可以使用函数表达式或函数声明定义。 函数声明是定义函数的最简单方式,它使用“function”关键字和函数名称来声明一个函数,例如: ``` function greeting() { console.log("Hello World"); } ``` 这里定义了一个简单的函数,功能是输出“Hello World”到控制台。我们可以通过使用函数名来调用它: ``` greeting(); ``` 输出结果为“Hello World”。 除了函数声明外,还有一种常见的函数定义方式——函数表达式。函数表达式是定义一个函数并将其赋值给一个变量,例如: ``` var greeting = function() { console.log("Hello World"); }; ``` 这里定义了一个变量greeting,并将一个匿名函数赋值给它。我们可以通过使用变量名来调用该函数: ``` greeting(); ``` 输出结果为“Hello World”。 JavaScript函数支持一个特殊的参数对象——arguments对象,它可以让我们在函数内部访问到所有传递给该函数的参数。例如: ``` function sum() { var result = 0; for (var i = 0; i < arguments.length; i++) { result += arguments[i]; } return result; } ``` 这里定义了一个函数sum,它可以计算任意数量的参数的和。我们可以使用以下代码来调用该函数并输出结果: ``` console.log(sum(1, 2, 3, 4)); //输出10 console.log(sum(10, 20)); //输出30 ``` 总的来说,JavaScript函数是一项非常重要的技能,它可以帮助我们更好的组织和管理我们的程序,并且可以帮助我们构建可重复使用的代码片段。掌握JavaScript函数,是掌握JavaScript编程的重要一步。 ### 回答3: JavaScript是目前世界上最流行的动态编程语言之一,已成为很多网站和Web应用程序的必选之一。JavaScript的函数是编写高度可重复使用的代码和组织逻辑的基本组成部分,也是JavaScript编程的核心。随着Web应用场景的复杂化,函数在JavaScript编程中的重要性越来越得到了认识和应用,学习和掌握JavaScript的函数是很有必要的。 JavaScript函数与其他编程语言中的函数类似,是一个代码块,可以接受参数,返回值,并可重复使用。JavaScript函数有两种常用的定义方式,分别是函数声明和函数表达式。函数声明是指在代码中提前声明一个函数,函数表达式是指将一个函数赋值给一个变量或常量。 在JavaScript函数中,参数和返回值都是可以选择性的。一个函数可以不需要参数也不需要返回值,也可以仅需要参数或仅需要返回值。使用参数可以让函数更加灵活和通用,参数可以是任何类型,包括字符串、数字、函数和对象等。返回值可以是任何JavaScript支持的类型,包括布尔类型、数字类型、字符串类型和数组等。 函数的作用域是JavaScript函数编程中的一个关键概念,它指的是一段代码能够访问和操作的变量和函数的范围。JavaScript函数有词法作用域,即变量的作用域取决于它们在代码中的位置,作用范围被限定在函数内部和它所嵌套的函数中。 常用的JavaScript函数应用包括数组和对象的处理、事件处理和DOM操作等。在Web开发中,JavaScript函数和jQuery库的结合应用很广泛,它可以极大地提高Web应用的交互性和用户体验。 总之,JavaScript函数是一个必须掌握的编程概念,它可以让我们的代码更加灵活、通用、数据安全、易使用和易维护。了解JavaScript函数的语法和应用场景,能够有效地提高JavaScript编程的效率和质量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值