JavaScript 小括号()分组运算符

小括号()可以作为分组运算符,以改变表达式的优先级。

代码实例如下:

 
  
[JavaScript] 纯文本查看 复制代码 运行代码
1
2
var a=(1+2)*4;
console.log(a);

输出值是12,分组运算符可以改变运算符的优先级,否则的话输出值是9。

扩展说明:

(1)很多教程说它是一个强制运算符,其实ECMAScript中,就没有强制运算符这么一个概念,它就是普通分组运算符。

(2)这也是为什么eval()函数将json格式字符串转换为对象需再嵌套一个小括号的原因,可以参阅使用eval()将json字符串转换为对象要多加一个小括号一章节。 

小括号还有其他作用,下面分别做一下介绍:

(1)函数声明和函数调用参数列表:

声明函数或者调用函数的时候,如果有参数,那么就将参数放在小括号之中。

代码如下:

 
  
[JavaScript] 纯文本查看 复制代码
1
2
3
4
function func(a,b){
   //代码
}
func(1,2);

(2)与特定关键字形成特定语句:

小括号可以与特定的关键词形成特定的语句。

代码如下:

 
  
[JavaScript] 纯文本查看 复制代码
1
2
3
4
5
6
7
8
9
if (a>1){
   //代码
}
while (i
   //代码
}
for ( var i=0;i
   //代码
}

(3)表达式方式函数声明和立即调用函数表达式:

创建一个函数除了函数声明方式声明之外,还可以使用表达式方式。

代码如下:

 
  
[JavaScript] 纯文本查看 复制代码
1
2
3
4
5
6
function func(){
   //代码
}
var func= function (){
   //代码
}

第二种就是表达式方式声明一个函数。下面介绍一下函数声明和表达式方式的区别:

函数声明必须带有标识符,也就是函数名,但是函数表达式方式,标识符带不带都可以。

 
  
[JavaScript] 纯文本查看 复制代码
1
2
function 函数名称 (参数:可选){ 函数体 } //函数声明方式
function 函数名称(可选)(参数:可选){ 函数体 } //函数表达式方式

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

 
  
[JavaScript] 纯文本查看 复制代码
1
2
function func(){}; //函数声明方式
( function func(){}) //函数表达式方式

出现在运算符相关上下文中,那么它就是一个表达式,例如下面最常见的代码:

 
  
[JavaScript] 纯文本查看 复制代码
1
var func= function (){}

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

 
  
[JavaScript] 纯文本查看 复制代码
1
2
3
( function (){})();
( function (){}());
! function (){}();

三个语句都是在运算符相关上下文中,所以都是表达式,下面做一下分析:

(1)(function(){})():一个表达式,会强制其理解成函数直接量,也就是表达式方式创建函数,(function(){})它会返回函数对象的引用,相当于函数对象的函数名,最后使用小括号()调用此函数。

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

(3)!function(){}():由于!也是一个运算符,所以原理同上。

以上三种方法没有任何区别,可互相通用。

你可能感兴趣的:(Web前端)