关于 function 函数的总结

关于函数调用的问题:

function t() {
    console.log("1111");
    return 1111
}

add("transitionend", t) //调用整个函数 function t(){.....}
add("transitionend", t()) //调用函数返回的结果 1111
复制代码

关于 !function(){} :当即调用函数

!function跟(function(){... })();函数意义相同,叫作当即运行的匿名函数(也叫当即调用函数)。bash

js中能够这样建立一个匿名函数:函数

(function(){
    do something...
})()复制代码

//或ui

(function(){
    do something...
}())
复制代码

而匿名函数后面的小括号()是为了让匿名函数当即执行,其实就是一个函数调用。
spa

这样写会报错:code

function(){
    alert(1)
}()
复制代码

由于function前面没有(或者! ~之类的运算符,js解析器会试图将关键字function解析成函数声明语句,而不是函数定义表达式。
string

做为组运算符,小括号()会将其内部的表达式当成一个总体,而后返回结果,因此定义一个匿名函数正确的格式就是用小括号将函数体括起来。it

一样的! ~ + -等运算符也有一样的效果,这是由于匿名函数也是一种值,这些运算符会将后面的函数体当成一个总体,先对匿名函数进行求值,而后在对结果进行运算。io

不过这些运算符虽然可以达到让匿名函数当即执行的目的,可是要当心他们是有反作用的,好比:console

!function() {return 1}() //false
~function() {return 1}() //-2
-function() {return false}() //0
-function() {return false}() //0
复制代码

没错,他们会对函数的返回值进行运算,这样可能会致使最终的结果和你想要的结果不同。固然,对于那些没有返回值的函数来讲,固然是没有什么影响了。function

关于function() 后面跟小括号问题

var i= 0;
function f(){
	i++;
	console.log("-------------: " + i)
	return k;
	function k(e) {
		return e
	}
}

f();
console.log("111111111111")
f()()
console.log(f()("I love you!"))

/*
执行结果:
-------------:  1
111111111111
-------------:  2
-------------:  3
I love you!
*/复制代码

f 函数后面跟的小括号意义是 执行并返回 f 函数里面 的k 函数。若是小括号里面有值,会把 值赋值给 k 函数。

相关文章
相关标签/搜索