`
frank1998819
  • 浏览: 763703 次
  • 性别: Icon_minigender_1
  • 来自: 南京
文章分类
社区版块
存档分类

js 中{},[]中括号,大括号使用详解(转)

    博客分类:
  • JS
 
阅读更多

js 中{},[]中括号,大括号使用详解

作者: 字体:[增加 减小] 类型:转载
<!--end art_info-->
 
{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数
 
 
<!--NEWSZW_HZH_BEGIN-->一、{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数。
如:var LangShen = {"Name":"Langshen","AGE":"28"};
上面声明了一个名为“LangShen”的对象,多个属性或函数用,(逗号)隔开,因为是对象的属性,
所以访问时,应该用.(点)来层层访问:LangShen.Name、LangShen.AGE,当然我们也可以用数组的方式来访问,如:LangShen["Name"]、LangShen["AGE"],结果是一样的。
该写法,在JSON数据结构中经常用,除此之外,我们平时写函数组的时候,也经常用到,如:
复制代码 代码如下:

var LangShen = {
Name = function(){
return "LangShen";
},
Age = function(){
return "28";
}
}

调用方式差不多,因为是函数组,所以要加上(),如:alert( LangShen.Name() );
二、[ ]中括号,表示一个数组,也可以理解为一个数组对象。
如:var LangShen = [ "Name","LangShen","AGE","28" ];
很明显,每个值或函数,都是独立的,多个值之间只用,(逗号)隔开,因为是数组对象,所以它等于:
var LangShen = Array( "Name","LangShen","AGE","28" );
访问时,也是和数组一样,alert( LangShen[0] );
三、{ } 和[ ] 一起使用,我们前面说到,{ } 是一个对象,[ ] 是一个数组,我们可以组成一个对象数组,如:
复制代码 代码如下:

var LangShen = { "Name":"Langshen",
"MyWife":[ "LuLu","26" ],
"MySon":[{"Name":"Son1"},{"Name":"Son2"},{"Name":"Son3"}]
}

从上面的结构来看,是一个对象里面的第一项是个属性,第二项是一个数组,第三个是包含有多个对象的数组。调用起来,也是一层一层访问,对象的属性用.(点)叠加,数组用 [下标] 来访问。
如:alert( LangShen.MySon[1].Name ) ; <!--NEWSZW_HZH_END-->

您可能感兴趣的文章:

解析Javascript中大括号“{}”的多义性

 

作者: 字体:[增加 减小] 类型:转载

<!--end art_info-->

 

 

这篇文章主要介绍了Javascript中大括号“{}”的多义性。需要的朋友可以过来参考下,希望对大家有所帮助

 

 

 

 

 

<!--NEWSZW_HZH_BEGIN-->

JS中大括号有四种语义作用

语义1,组织复合语句,这是最常见的

复制代码 代码如下:

if( condition ) {
//...
}else {
//...
}
for() {
//...
}

语义2,对象直接量声明
复制代码 代码如下:

var obj = {
name : 'jack',
age : 23
};

整个是个赋值语句,其中的{name:'jack',age:23}是个表达式。

 

语义3,声明函数或函数直接量

复制代码 代码如下:

function f1(){
//...
}

var f2 = function(){
//...
}

f1与非f2的区别是前者在语法解释期,后者在运行期。区别在于:如果调用该函数的代码在函数定义之后,则没有区别;如果调用该函数的代码在函数定义之前,则f1仍然可以调用,f2则会报错,提示f2未定义。

 

语义4,结构化异常处理的语法符号

复制代码 代码如下:

try {
//...
}catch( ex ){
//...
}finally{
//...
}

这里的大括号与符合语句(语义1 )是有区别的,大括号中如果只有一条语句,在if/else/for等中大括号是可以省略的,但try/catch/finally则不能省略。

 

以下代码纠结了偶N久

复制代码 代码如下:

function(){}() //匿名函数立即执行, 语法分析期报
{}.constructor //获取对象直接量的构造器,语法分析期报错

令人不解的是为何[].constructor这么写却不报错呢,一个是想获取对象直接量的构造器,一个是获取数组直接量的构造器而已。

 

当然添加个变量接收也不会报错

var c = {}.constructor;

同样的情况如

var fn = function(){}(),也不会报错。

实际上是js的“语句优先”在作怪,即{}被理解成复合语句块(语义1 )而不是对象直接量(语义2 )或声明函数(语义3 )的语义。

function(){}(),大括号被理解成复合语句,自然前面的function()声明函数的语法不完整导致语法分析期出错。

{}.constructor,大括号被理解成复合语句,大括号后面是点运算符,点运算符前没有合理的对象自然也报错。

修复方式众所周知:加个强制运算符()
(function(){})(),(function(){});//强制其理解为函数(语义3 ),“函数()”表示执行该函数,即声明后立即执行了。

({}).constructor //({})强制把大括号理解成对象直接量(语义2 ),“对象.xx”表示获取对象的成员,自然后面的点运算符可以正常执行了。

分享到:
评论

相关推荐

    js 中{},[]中括号,大括号使用详解

    在JavaScript中,大括号{}和中括号[]是非常基础且重要的符号,它们分别用于定义对象和数组。下面将详细讲解这两种符号的使用方法...在实际开发中,灵活使用大括号和中括号能够帮助我们更好地组织和管理代码中的数据。

    javaScript使用详解.pdf

    3. 函数:JavaScript中的函数是第一类对象,可以作为变量赋值、作为参数传递、作为返回值。函数定义可采用function关键字或ES6的箭头函数(() =&gt; {})。 二、JavaScript对象 1. 对象创建:通过字面量方式({key: ...

    js正则表达式详解

    例如,在JavaScript中,如果你想匹配包含"cat"的字符串,但不区分大小写,可以使用正则表达式`/cat/i`。其中`i`标志表示忽略大小写。如果没有指定标志,则默认大小写敏感,如`/cat/`。如果想要匹配以`t`开头以`n`...

    JavaScript使用详解,javascript入门教程

    这个"JavaScript使用详解"教程覆盖了JavaScript的各个方面,结合视频和PDF资料,为初学者提供了全面的学习资源。通过学习,你可以掌握JavaScript的基本语法和高级特性,为网页开发打下坚实基础。

    JavaScript ES6中CLASS的使用详解

    在类中定义的方法中使用this关键字,可以引用当前实例的属性或执行其他操作。 除了类声明(class declaration),ES6还提供了类表达式(class expression),这种方式类似于函数表达式,可以将一个函数赋值给变量。...

    js中 javascript-void(0) 用法详解.docx

    ### JavaScript中的 `void(0)` 用法详解 #### 一、`void(0)` 的基本概念 在JavaScript中,`void(0)` 是一种特殊的语法结构,它主要用于执行某些处理,同时避免整个页面的刷新。`void` 是一个运算符,其功能是计算...

    javaScript 正则表达式详解

    选择、分组和引用序列是指在正则表达式中使用竖线 | 选择左边或右边的子表达式。括号 () 可以将多个项组合为一个单元,并捕获匹配的字符串。 指定匹配位置模式 指定匹配位置模式是指 ^ 匹配字符串的起点,$ 匹配...

    javascript正则表达式使用详解

    JavaScript中的正则表达式是一...在JavaScript中,正则表达式是通过`RegExp`对象或者直接在字符串中使用正则表达式语法来创建和使用的。掌握正则表达式能极大地提升文本处理和数据验证的能力,是编程中不可或缺的技能。

    JavaScript数组用法详解

    "JavaScript数组用法详解" JavaScript 数组是一种非常重要的数据结构,它是一种可以存储多个元素的集合。 JavaScript 数组的元素可以是任何类型,包括数字、字符串、对象、函数等。数组的长度可以动态地变化,可以...

    详解JavaScript中的异常处理方法

    在JavaScript中,主要的异常处理方法包括try...catch语句,throw语句以及finally子句的使用。异常处理机制能够在程序运行期间遇到错误时,提供一种控制错误处理流程的途径。 在JavaScript编程中,错误可以分为三大...

    正则中的圆括号()的用途详解

    - **量词**:使用大括号{}定义匹配次数,如{n}匹配前面的元素恰好n次,{n,}至少匹配n次,{n,m}匹配前面的元素至少n次但不超过m次。 ### 正则表达式中括号的区别 除了圆括号之外,正则表达式中还经常用到方括号[]和...

    JavaScript工作原理及对象详解.docx

    点表示法适用于已知的属性名称,而中括号表示法则允许使用变量来动态访问属性,特别适合处理包含特殊字符或关键词的属性名。同时,对象中的函数(或称方法)被视为可调用的属性,如`obj.sayName()`,需使用括号调用...

    javascript正则表达式详解

    3. **高级分组**:Jakarta-ORO的分组功能更强大,包括非捕获组和命名组,JavaScript中可以通过括号和`?:`来实现非捕获组,但命名组需要借助额外的库如`XRegExp`。 **四、实例与实践** 1. **验证邮箱地址**:`/^\w+...

    js中的string.format函数代码.docx

    JS 中的 string.format 函数代码详解 JS 中的 string.format 函数代码是 JavaScript 中的一种格式化字符串的方法,该方法可以将变量的值插入到字符串中,从而生成一个完整的字符串。下面将详细介绍 JS 中的 string....

    详解JavaScript中js对象与JSON格式字符串的相互转换

    例如,`{"f[name]": "张三"}` 在转换后会成为带有引号属性的JS对象,因此访问该属性时需要使用 `jsObj4['f[name]']`,而不是 `jsObj4.f[name]`,因为后者在JavaScript中是无效的。 接下来,我们讨论将JS对象转换为...

    JavaScript中setMonth()方法的使用详解

    javascript Date.setMonth()方法按照本地时间设置每月指定日期。 语法 Date.setMonth(monthValue[, dayValue]) 注:括号内外观和数据是可选的 下面是参数的详细信息: monthValue : 从0到11的整数(表示个月份,从...

    JS正则表达式详解

    在JS中,正则表达式以`/pattern/flags`的形式表示,其中`pattern`是正则表达式的模式字符串,`flags`是可选参数,用于指定正则表达式的某些行为,如`i`代表不区分大小写,`g`表示全局匹配等。 #### 常用元字符与...

    javascript正则表达式中分组详解_.docx

    例如,在JavaScript中,可以使用`match`或`exec`方法获取到这些分组匹配到的结果。 ##### 2.1 示例 假设我们需要从字符串`"new test001 test002"`中提取出`test`后面的数字: ```javascript var reg = /test(\d+)...

    vue双花括号的使用方法 附练习题

    在数据对象中,我们可以定义多个属性,例如 `cart`,并在 HTML 元素中使用双花括号来插入这些属性的值。 二、 在双花括号中执行运算表达式 除了插入简单的数据外,Vue 双花括号还可以在双花括号中执行运算表达式。...

Global site tag (gtag.js) - Google Analytics