大家好,我是半夏👴,一个刚刚开始写文的沙雕程序员.

函数可以做任何事情,而 JavaScript 的真正威力来自于定义自己的函数。

函数将一组指令组合在一起,通常接收值(我们之前讨论过参数),做一些工作,然后将值或一组值返回给请求的值。

通常一个函数的一生包括:定义,调用!

创建一个函数时并编写它的功能时,这称为函数定义

运行该函数时,称为调用运行函数。

定义函数

有几种方法可以定义函数,最基本的是:使用function来定义函数。

function getUserName() {
  // 函数体
}

函数内部的任何内容都称为函数体

在函数体中,添加👇

console.log("获取用户姓名");

函数就像变量一样工作,您可以通过它的名称来调用它们。但是,当您只输入函数的名称时,您会看到整个代码,如下图👇 所示

javascript function 里面再定义function javascript 函数定义_前端

现在,如果我们要运行该函数,我们直接在函数名后面加上括号。

javascript function 里面再定义function javascript 函数定义_javascript_02

当我们getUserName()在控制台中调用时,它返回 undefined。通常,函数会做大量工作,然后将结果返回给您。

我们将在我们的函数中做的是我们将接受一个用户对象。

let person = {
     name : '搞前端的半夏',
     age : 18,
  }

函数最终将会把name返回给我们。

function getUserName(user) {
  let userName=user.name
  return userName
}

javascript function 里面再定义function javascript 函数定义_前端知识_03

你可能会想。我们用let定义了一个userName变量,我们可以访问它,为啥还要返回值。但是在控制台输入userName,它将返回

not defined,

javascript function 里面再定义function javascript 函数定义_javascript_04

这就是我们要讨论的作用域,在函数内部创建的变量仅在该函数中可用,这称为块作用域*(我们将在后面更详细地介绍块)*。它在它之外不可用。

函数有了返回值,我们可以用一个变量接受。

let userName=getUserName(person)
console.log(userName)

javascript function 里面再定义function javascript 函数定义_前端_05

这里我们用的名字也是userName,但他并不会报错,这是因为函数内部的userName是一个临时变量。他只可以在函数内部使用,并且在函数运行完成时,被JS自动清理了,也即是JS的垃圾收集。