函数做为参数传递

进行函数传递

举例来讲,你能够这样作:函数

function say(word){
  console.log(word);
}

function execute(someFunction, value){
  someFunction(value);
}

execute(say,"Hello");

请仔细阅读这段代码!在这里,咱们把 say 函数做为execute函数的第一个变量进行了传递。这里返回的不是say 的返回值,而是 say 自己!spa

这样一来, say 就变成了execute 中的本地变量 someFunction ,execute能够经过调用 someFunction() (带括号的形式)来使用 say 函数。ip

固然,由于 say 有一个变量, execute 在调用 someFunction 时能够传递这样一个变量。io

咱们能够,就像刚才那样,用它的名字把一个函数做为变量传递。可是咱们不必定要绕这个“先定义,再传递”的圈子,咱们能够直接在另外一个函数的括号中定义和传递这个函数:console

function execute(someFunction, value){
  someFunction(value);
}

execute(function(word){ console.log(word)},"Hello");

咱们在 execute 接受第一个参数的地方直接定义了咱们准备传递给 execute 的函数。function

用这种方式,咱们甚至不用给这个函数起名字,这也是为何它被叫作 匿名函数 。匿名函数

这是咱们和我所认为的“进阶”JavaScript的第一次亲密接触,不过咱们仍是得按部就班。如今,咱们先接受这一点:在JavaScript中,一个 函数能够做为另外一个函数接收一个参数。咱们能够先定义一个函数,而后传递,也能够在传递参数的地方直接定义函数。变量

相关文章
相关标签/搜索