Tip: 内容摘抄自《JavaScript权威指南》,看过该书的同学可以忽略本文。

存取一个对象的属性的方式:

  obj.attr;

  obj["attr"];

两者最重要的区别就是前者的属性名是标示符,后者的属性名是一个字符串

用"."运算符来存取一个对象的属性时,属性名是标示符,JavaScript程序中,标示符必须被逐字输入,它们不是一种数据类型,因此程序不能对他们进行操作。

用数组的概念"[]"来存取一个对象的属性时,属性名是用字符串表示的。字符串是JavaScript的一种数据类型,因此可以在程序运行的过程中操作并创建他们。

关联数组

  obj["attr"];

  如果使用一个对象是采用的是这种形式,我们常常称它为关联数组。关联数组是一种数据结构,允许你动态的将任意的数值和任意的字符串关联在一起。实际上,JavaScript对象的内部实现就是关联数组。

应用场景(obj["attr"])

  当你需要编写一个程序,允许yonghu输入他所拥有的股票的名字和相应的份额来计算用户在股票市场投资的当前值,你可以这样做。

  使用一个portfolio对象来保存这些信息,用户输入的每只股票的名字作为该对象的一个属性,其值为该支股票拥有的份额。例如:用户拥有Netscape公司的股票,份额为50,就有portfolio.nscp = 50;

  这个程序需要一个循环,首先提示用户输入股票名,然后输入他拥有的份额。

  由于用户在程序运行时输入股票名(portfolio对象的属性),所以你无法预先知道这些股票名是什么,所以在编程时不能使用"."运算符的方式,但可以使用"[]"关联数组的方式,因为他的属性名是一个字符串,程序运行时可以动态创建。

  下面是具体的代码

(function(){
var portfolio = {};
var name,value,sum=0;//定义股票名/份额/投资当前值(总金额)
while(true){//输入股票名和份额并写入到portfolio对象中
if(!(name = prompt("请输入一支股票名","nscp") || false))break;
if(!(value= prompt("请输入您拥有的份额",50) || false))break;
portfolio[name] = +value;
}
for(e in portfolio){//遍历计算投资当前值(总金额)
sum +=portfolio[e]*1;//假设每支股票都是1元, 每支股票数量*股票价格
}
console.log(sum);//输出
})();

  由于股票名是未知的,如果没有for/in循环,我们不能编写出这样的代码,输出属性名并计算结果。这是将属性名从portfolio对象中抽取出来的唯一方法

注意:

for(e in portfolio){
sum +=portfolio[e]*1;
}

中,e得到的只是portfolio的属性名,并不是属性名对应的属性值,所以 ”portfolio[e]“ 的写法是必要的

除此之外,你还可以看看这篇文章,内容差不多  [导入]js 关联数组 详解

JavaScript对象之关联数组的更多相关文章

  1. javaScript高级教程(三) javaScript不支持关联数组,只是语法上像关联数组

    1.在js中所有要素都是继承自Object对象的,任何对象都能通过obj['name'] = something的形式来添加属性,相当于obj.name=something. 之所以设计中括号这种存取 ...

  2. javascript中的关联数组

    所谓关联数组(associative array), 就是指javascript中的对象. 因为javascript中的属性就是一个个的键值对,可以通过obj[attr]的方式访问,很类似数组. 这种 ...

  3. javascript对象属性和数组的访问

    javascript对象属性的访问 假如有对象test:var test = {  "a":1,  "b":2};直接访问对象test的属性a的值,有两种方法: ...

  4. JavaScript高级 面向对象(11)--对象的动态特性-关联数组用法

    说明(2017.4.2): 1. 对象的动态特性: (1)在js中,一个对象需要属性,就可以利用“对象名.属性 = 值”的方式为其添加,只要赋值成功,对象就新增这个属性. (2)对象属性的访问形式: ...

  5. javascript对象深拷贝,浅拷贝 ,支持数组

    javascript对象深拷贝,浅拷贝 ,支持数组 经常看到讨论c#深拷贝,浅拷贝的博客,最近js写的比较多, 所以也来玩玩js的对象拷贝. 下面是维基百科对深浅拷贝的解释: 浅拷贝 One meth ...

  6. 好程序员web前端分享javascript关联数组用法总结

    好程序员web前端分享javascript关联数组用法总结,有需要的朋友可以参考下. Hash关联数组定义 代码如下 // 定义空数组 myhash = { } // 直接定义数组 myhash = ...

  7. JavaScript 对象与数组参考大全

    http://www.cnblogs.com/meil/archive/2006/06/28/437527.html本文列举了各种JavaScript对象与数组,同时包括对上述每一对象或数组所完成工作 ...

  8. JavaScript 浅析数组对象与类数组对象

    数组(Array对象) 数组的操作 创建数组方法 添加与修改数组元素 删除数组元素 使用数组元素 遍历数组元素 多维数组 数组相关的函数 concat() join() pop() push() sh ...

  9. 简述JavaScript对象、数组对象与类数组对象

    问题引出 在上图给出的文档中,用JavaScript获取那个a标签,要用什么办法呢?相信第一反应一定是使用document.getElementsByTagName('a')[0]来获取.同样的,在使 ...

随机推荐

  1. 201521123089 《Java程序设计》第7周学习总结

    一.本周学习总结 1.以你喜欢的方式(思维导图或其他)归纳总结集合相关内容. 二.书面作业 1.ArrayList代码分析 1.1 解释ArrayList的contains源代码 如果对象为空,ele ...

  2. 201521123078 《java》第五周学习总结

    1. 本周学习总结 1.1 尝试使用思维导图总结有关多态与接口的知识点. 2. 书面作业 代码阅读:Child压缩包内源代码 1.1 com.parent包中Child.java文件能否编译通过?哪句 ...

  3. 在linux下通过hexdump生成一个十六进制的文本保存文件,解析此文件转变成正常源代码文件。

    举例说明: 此十六进制保存的文件为此源代码hexdump生成的: #include<stdio.h> #include<string.h> #include<stdlib ...

  4. 使用vue-router实现返回

    在vue项目中使用vue-router做路由,做到返回页面的逻辑时,由于window.history.back满足不了返回的需要,故想通过 window.addEventListener('popst ...

  5. 安装wampserve之前需要安装vc++2012.

    本人是64位系统下载了wampserver3.0.6之后安装好,启动报错缺少msvcr110.dll. 于是从网上下载了msvcr110.dll放到了windows的syswow64文件夹下,甚至还重 ...

  6. 关于Java中数组的常用操作方法

    1. 声明一个数组 String[] arr1 = new String[5]; String[] arr2 = {"a","b","c", ...

  7. MongoDB的备份和部署 高级功能索引,聚合复制,分片

    创建备份 MongoDB 数据转储 为了在 MongoDB 中创建数据库备份,需要使用 mongodump 命令.该命令会将服务器上的所有数据都转储到 dump 目录中.你可以使用很多选项来限制转储的 ...

  8. MySQL binlog 的恢复操作

     测试出有个问题:mysqlbinlog 不加任何参数 恢复整个binlog 日志文件发现里面有这个操作 SET @@SESSION.GTID_NEXT 的操作,  如果需要恢复文件的时候就需要把他过 ...

  9. 内核对象 windows操作系统

    问题: 什么是内核对象? 答:内核对象实际上时由内核分配的一块内存,而且只能由内核来访问.它时一个数据结构,成员包含有关于该对象的信息.一些成员对于所有对象类型都是一样的,比如对象名称.安全描述.使用 ...

  10. 原型模式和基于原型继承的js对象系统

    像同样基于原型编程的Io语言一样,javascript在原型继承方面,实现原理和Io非常类似,javascript也遵守这些原则 所有数据都是对象 要得到一个对象,不是通过实例化类,而是找到一个对象作 ...