js小括号的作用

假如你现在还在为自己的技术担忧,假如你现在想提升自己的工资,假如你想在职场上获得更多的话语权,假如你想顺利的度过35岁这个魔咒,假如你想体验BAT的工作环境,那么现在请我们一起开启提升技术之旅吧,详情请点击http://106.12.206.16:8080/qingruihappy/index.html

 

js中小括号()的用法详解:
对于小括号无论是菜鸟还是高手一定都不会陌生,可以说它几乎是随处可见,虽然熟悉但并非真正的理解,由此可能会产生很多莫名其妙的错误,下面就通过代码实例详细介绍一下小括号的用法。
更多的关于js运算符内容可以参阅JS教程版块。
一.作为分组运算符:
分组运算符应该是再熟悉不过了,因为在小学数学中就有应用,例如:

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


以上代码的输出值是12,因为分组运算符可以改变运算符的优先级,否则的话输出值是9。
扩展说明:
1.很多教程说它是一个强制运算符,其实在ECMAScript中,根本就没有强制运算符这么一个概念,它就是普通分组运算符。
2.这也是为什么eval()函数将json格式字符串转换为对象需再嵌套一个小括号的原因,可以参阅使用eval()将json字符串转换为对象要多加一个小括号一章节。 
二.函数声明和函数调用参数列表:
在声明函数或者调动函数的时候,如果有参数,那么就会将参数放在小括号之中,代码如下:

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


三.与特定关键字形成特定语句:
小括号可以与特定的关键词形成特定的语句,代码如下:

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


四.表达式方式函数声明和立即调用函数表达式:
创建一个函数除了函数声明方式声明之外,还可以使用表达式方式,代码如下:

[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(){})是一个表达式,会强制其理解成函数直接量方式,也就是表达式方式创建函数,(function(){})它会返回函数对象的引用,最后使用小括号()调用此函数。
2.(function(){}()),如果不用外面包裹的小括号,{}就会理解为复合语句,那么function(){}就被理解为函数声明,但是没有标识符,所以会报错,使用小括号以后,就会变成表达式,也会被理解为直接量方式。
3.!function(){}(),原理同上,!也是一个运算符,所以在原理同上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值