举例来讲,你能够这样作:函数
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中,一个 函数能够做为另外一个函数接收一个参数。咱们能够先定义一个函数,而后传递,也能够在传递参数的地方直接定义函数。变量