javascript的 {} 语句块详解
作者:bea
今日学习解析json字符串,用到了一个eval()方法,解析字符串的时候为什么需要加上括号呢?摸不着头脑。原来javascript中{}语句块具有二义性,不加括号会出错,理解这种二义性对我们理解javascript代码有极大帮助。 一、{}语句块的两个含义 表示语句块 a. 在javascript中可以使用{}来括起代码,在编辑器中方便管理代码。因为javascript并没有块级作用域,所以这种写法是无害的。 {//some code...} b. 在javasc
今日学习解析json字符串,用到了一个eval()方法,解析字符串的时候为什么需要加上括号呢?摸不着头脑。原来javascript中{}语句块具有二义性,不加括号会出错,理解这种二义性对我们理解javascript代码有极大帮助。
一、{}语句块的两个含义
表示语句块
a. 在javascript中可以使用{}来括起代码,在编辑器中方便管理代码。因为javascript并没有块级作用域,所以这种写法是无害的。
{
//some code...
}
b. 在javascript中 ,条件判断语句,循环语句,函数都需要{}语句块来整合代码
对象字面量
var box = {
name:'kuoaho',
age:21
}
//此时[code]作为表达式,可以赋值给一个变量 //其实对象字面量就是可以生成对象值的表达式
二、那如果对象字面量不作为一个赋值表达式,会发生什么情况呢?
example:
{name:'kuoao'} //没有报错,但是也没有创建对象
{name:'kuohao',age} //报错
由上面可以看出对象字面量只能够作为表达式赋值,第一种写法没有错,只是javascript将它作为一个label语句解析了。
analysis:
{name:'kuoao'}
//{}一个语句块
// name:'kuohao',一个label语句,用于标记for循环
三、但是问题又来了……
{
name:'kuohao',
age:21
}
//这样为什么会报错?这不是对象字面量的写法吗? 因为javascript中{}的二义性,{}不仅仅被认为是对象字面量而且还会被认为是代码块。
analysis:
{
name:'kuohao',
age:21
}
一个代码块,两条label语句,如果没有逗号,是完全没有问题的,所以关键在于逗号,两条语句的分隔应该使用分号,所以javascript会判定这是语法错误
四、正确的写法
({
name:'kuohao',
age:21
})
//正确的写法
()会把语句转换成表达式,称为语句表达式,对象字面量不是表达式吗?为什么还需要()来转换?
加上括号以后,就可以消除这种二义性,因为括号里的代码都会被转换为表达式求值并且返回,因此语句块也就变成了对象字面量,也可以得出,对象字面量必须作为表达式而存在
有用 | 无用
一、{}语句块的两个含义
表示语句块
a. 在javascript中可以使用{}来括起代码,在编辑器中方便管理代码。因为javascript并没有块级作用域,所以这种写法是无害的。
{
//some code...
}
b. 在javascript中 ,条件判断语句,循环语句,函数都需要{}语句块来整合代码
对象字面量
var box = {
name:'kuoaho',
age:21
}
//此时[code]作为表达式,可以赋值给一个变量 //其实对象字面量就是可以生成对象值的表达式
二、那如果对象字面量不作为一个赋值表达式,会发生什么情况呢?
example:
{name:'kuoao'} //没有报错,但是也没有创建对象
{name:'kuohao',age} //报错
由上面可以看出对象字面量只能够作为表达式赋值,第一种写法没有错,只是javascript将它作为一个label语句解析了。
analysis:
{name:'kuoao'}
//{}一个语句块
// name:'kuohao',一个label语句,用于标记for循环
三、但是问题又来了……
{
name:'kuohao',
age:21
}
//这样为什么会报错?这不是对象字面量的写法吗? 因为javascript中{}的二义性,{}不仅仅被认为是对象字面量而且还会被认为是代码块。
analysis:
{
name:'kuohao',
age:21
}
一个代码块,两条label语句,如果没有逗号,是完全没有问题的,所以关键在于逗号,两条语句的分隔应该使用分号,所以javascript会判定这是语法错误
四、正确的写法
({
name:'kuohao',
age:21
})
//正确的写法
()会把语句转换成表达式,称为语句表达式,对象字面量不是表达式吗?为什么还需要()来转换?
加上括号以后,就可以消除这种二义性,因为括号里的代码都会被转换为表达式求值并且返回,因此语句块也就变成了对象字面量,也可以得出,对象字面量必须作为表达式而存在
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 基于JavaScript实现百叶窗动画效果不只单纯flas可以实现
- ClearTimeout消除闪动实例代码
- JavaScript实现点击按钮字体放大、缩小
- jquery trigger函数执行两次的解决方法
- 理解js回收机制通俗易懂版
- jquery trigger实现联动的方法
- 基于Javascript实现返回顶部按钮
- JavaScript实现斗地主游戏的思路
- jQuery取消特定的click事件
- JavaScript+CSS实现的可折叠二级菜单实例
- JS三级可折叠菜单实现方法
- 精通JavaScript的this关键字
- javascript正则表达式总结
- javascript计时器编写过程与实现方法
- javascript插件开发的一些感想和心得
- 详解Javascript中的Object对象
- Jquery跨浏览器文本复制插件Zero Clipboard的使用方法
- JavaScript实现iframe自动高度调整和不同主域名跨域
- Javascript技术栈中的四种依赖注入小结