JS中的括号和点号
admin
2024-02-10 22:22:34
0

使用中括号运算符[]可以存取数组元素值,使用点运算符.可以存取对象属性值。其语法格式如下:

  1. a.b //点运算符的用法
  2. c[b] //中括号运算符的用法

操作数 a 表示对象,操作数 b 表示属性名。如果属性值是函数,应增加小括号,实现方法调用操作。注意,操作数 b 是不能使用字符串或字符串表达式的。

操作数 c 可以是数组,也可以是对象。具体说明如下:

  • 如果左侧操作数是数组,则中括号包含的操作数应是一个值为非负整数的表达式,作为下标值,用来指定元素在数组中的位置。
  • 如果左侧操作数是对象,则中括号包含的操作数应是一个值为字符串的表达式,映射对象的属性名。

中括号和点号应该属于运算符范畴,但是新版本 JavaScript 把它们视为语言核心命令来使用。

示例1

使用中括号运算符[]不仅可以存取数组元素的值,也可以存取对象属性值。
1) 存取数组元素的值。

  1. var a = [1,"x",true,{}]; //定义数组a
  2. console.log(a[1]); //读取第二个元素的值,返回字符串"x"
  3. a[3] = false; //为第4个元素写入false值
  4. console.log(a[3]); //第四个元素原来的值被覆盖,返回false

2) 存取对象属性的值。

  1. var a = { //定义对象a
  2. x : 1, //定义对象属性x
  3. y : function() { //定义对象方法y
  4. return 2; //返回值
  5. }
  6. };
  7. console.log(a["y"] ()); //调用方法y,返回2
  8. a["x"] = 3; //重置属性x的值
  9. console.log(a["x"]); //读取属性x的值,返回3

示例2

使用点运算符.可以存取对象属性的值,它比中括号灵活、方便,因为点运算符右侧可以直接指定属性名称,而不是属性名称的字符串。

  1. var a = {x : 1}; //定义对象a
  2. console.log(a.x); //返回1。读取对象属性a的值
  3. a.x = 2; //重写对象属性a的值
  4. console.log(a.x); //返回2。再次读取对象属性a的值

对于中括号运算符,可以通过变量或字符串表达式来传递特定值。

  1. var b = "x"; //把属性x的标识符名作为字符串存储在变量b中
  2. var a = {x : 1}; //定义对象a
  3. console.log(a[b]); //返回1。通过变量间接获取对象a的属性x的值
  4. console.log(a.b); //返回undefined。点运算符无法识别变量引用

示例3

下面两种方法都可以读取数组 a 的第二个元素值。虽然说 a[“1”] 中参数是一个字符串,但是中括号运算符能够把它转换为数字。

  1. var a = ["x",true,{}]; //定义数组
  2. console.log(a[1]); //返回true
  3. console.log(a["1"]); //返回true

如果中括号运算符的第二个操作数为对象,会调用 toString() 方法把对象转换为字符串表示。如果是布尔值 true 和 false,将被转换为字符串 “true” 和 “false”,而不是 1 和 0。

  1. var a = { //定义对象
  2. "true" : 1, //定义属性“true”
  3. "false" : 0 //定义属性“false”
  4. }
  5. console.log(a[true]); //返回1。把布尔值true转换为字符串“true”
  6. console.log(a[false]); //返回0。把布尔值false转换为字符串“false”

示例4

在不确定对象属性时,使用中括号运算符来遍历对象属性会很方便,但如果使用点运算符则容易引发异常。下面代码使用中括号运算符变量客户端 window 对象的所有属性以及属性值。

  1. for(o in window){
  2. document.write("window." + o + "=" + window[o] + "
    ");
  3. }

相关内容

热门资讯

消息称百度旗下昆仑芯瞄准500... 6 月 29 日消息,据《The Information》昨日援引知情人士消息,百度旗下 AI 芯片...
打造夏日消费新场景 第35届北... 北京商报讯(记者 翟枫瑞)6月29日消息,第35届北京国际燕京啤酒文化节新闻发布会在京举行。本届啤酒...
社保基金持仓数据出炉,一季度增... 最近各大上市公司一季度财报都公开了,咱们国家社保基金的持仓数据也全部曝光。目前社保拿着比亚迪价值44...
36氪首发 | 海思、中兴团队... 作者 | 乔钰杰 编辑 | 袁斯来 硬氪获悉,广州宸思通讯科技有限公司(以下简称“宸思科技”)近日完...
两天蒸发47亿市值!一纸税务通... 一纸税务通知书,能让一家百亿龙头两天蒸发47亿市值。 6月22日,北大荒(600598.SH)公告称...
SK海力士将投资1100万亿韩... SK集团会长崔泰源6月29日在韩国“三大重大计划”发布会上宣布,公司将投资1100万亿韩元扩大半导体...
两只A股,终止上市! 两家A股公司,即将摘牌。 6月29日,退市沪科(600608.SH)公告称,上海证券交易所将在202...
原创 M... 一家成立近十年的自动驾驶公司,在IPO时吸引了14家基石投资者认购近一半的发行股份,其中不乏奔驰、比...
基金忠言|国寿安保滤镜碎,三年... 图片来源:视觉中国 蓝鲸新闻6月29日讯(记者 祁和忠)保险系基金公司国寿安保总经理换人了。 6月2...
三星电机计划加码玻璃基板!相关... 6月29日,玻璃基板概念股午后有所回升, 华工科技(000988.SZ)逼近涨停, 彩虹股份(600...
拉萨海关持续壮大外贸经营主体 ...   新华网拉萨6月28日电(记者蒋梦辰)近日,记者从拉萨海关获悉,今年前5个月,西藏有进出口实绩的外...
机构:二季报临近,医药生物板块... 6月29日,华源证券发布了一篇医药生物行业的研究报告,报告指出,业绩期临近,产业链景气度有望再次迎来...
每日收评科创50放量涨超4.5... 财联社6月29日讯,三大指数全线收红,创业板指探底回升,科创50指数大涨4.61%。沪深两市成交额3...
6月多地土拍结构性升温:深圳单... 进入2026年6月,不少城市核心区地块集中诞生高溢价宗地,热度突出的城市包含深圳、杭州、长沙。 其中...
业绩炸裂!盛达资源半年预盈3.... 6月29日,贵金属矿山龙头盛达资源(000603.SZ)发布 2026 年半年度业绩预告,上半年业绩...
A股午后拉升三大股指收涨:半导... A股三大股指6月29日开盘涨跌互现。早盘沪强深弱,创指一度跌超2%。半导体午后拉升,带动两市上涨,沪...
原创 空... 前言 大家好,我是老金。 这几天,两幅极度割裂的画面放在一起,把我看笑了。 一边是在持续的热浪下,欧...
澳大利亚审慎监管局拟放宽银行风... 澳大利亚审慎监管局(APRA)6月29日就修改 银行信用风险资本设定公开征求意见,旨在加大信贷投放以...
全民炒股,急踩刹车!韩国股市突... 屈红燕/证券时报网 全民狂欢、交易高度拥挤、杠杆资金猛增、新入市投资者表现激进、大型IPO吸金等现象...