js中小括号()的用法详解

1、js中小括号()的用法详解web

一、做为分组运算符:json

分组运算符应该是再熟悉不过了,由于在小学数学中就有应用,例如:svg

var a=(1+2)*4;
console.log(a);
以上代码的输出值是12,由于分组运算符能够改变运算符的优先级,不然的话输出值是9。
扩展说明:
1.不少教程说它是一个强制运算符,其实在ECMAScript中,根本就没有强制运算符这么一个概念,它就是普通分组运算符。
2.这也是为何eval()函数将json格式字符串转换为对象需再嵌套一个小括号的缘由,能够参阅使用eval()将json字符串转换为对象要多加一个小括号一章节。函数

二、函数声明和函数调用参数列表:
在声明函数或者调动函数的时候,若是有参数,那么就会将参数放在小括号之中,代码以下:xml

function func(a,b){
//代码
}
func(1,2);对象

三、与特定关键字造成特定语句:
小括号能够与特定的关键词造成特定的语句,代码以下:教程

if(a>1){
//代码
}
while(i<len){
//代码
}
for(var i=0;i<len;i++){
//代码
}ip

四、表达式方式函数声明和当即调用函数表达式:
建立一个函数除了函数声明方式声明以外,还可使用表达式方式,代码以下:字符串

function func(){
//代码
}
var func=function(){
//代码
}数学

第二种就是表达式方式声明一个函数。下面介绍一下函数声明和表达式方式的区别:
函数声明必须带有标识符,也就是函数名,可是函数表达式方式,标识符带不带均可以。

function 函数名称 (参数:可选){ 函数体 }//函数声明方式
function 函数名称(可选)(参数:可选){ 函数体 }//函数表达式方式

要区分一个代码是函数声明仍是函数表达式,那要看代码的应用上下文,例如:

function func(){};//函数声明方式
(function func(){})//函数表达式方式
出如今运算符相关上下文中,那么它就是一个表达式,例以下面最多见的代码:

1
var func=function(){}

上面介绍一下什么是函数表达式,下面就看一下如何当即调用函数表达式:

(function(){})();
(function(){}());
!function(){}();

上面三个语句都是在运算符相关上下文中,因此都是表达式,就能够强制调用了,下面作一下分析:
1.(function(){})(),(function(){})是一个表达式,会强制其理解成函数直接量方式,也就是表达式方式建立函数,(function(){})它会返回函数对象的引用,最后使用小括号()调用此函数。

2.(function(){}()),若是不用外面包裹的小括号,{}就会理解为复合语句,那么function(){}就被理解为函数声明,可是没有标识符,因此会报错,使用小括号之后,就会变成表达式,也会被理解为直接量方式。

3.!function(){}(),原理同上,!也是一个运算符,因此在原理同上。