javascript对象数组

时间:2009-11-20 09:56:28

标签: javascript arrays object

我需要将java中的代码迁移到javascript。 在java中,我使用key = string和value =对象的arraylist维护一个hashmap

我需要在javascript中实现相同的功能:

this.hashMap = new Hash();
this.hashMapArrayList =[];
...
var hashMapDataSet = new HashMapDataSet(id1,name1,type1);
this.hashMapArrayList[0] = hashMapDataSet;
...
this.hashMap.set(fileName1, this.hashMapArrayList);

var hashMapDataSet1= new HashMapDataSet(id2,name2,type2);
this.hashMapArrayList[0] = hashMapDataSet1;
this.hashMap.set(fileName2, this.hashMapArrayList);

但是当我尝试获取指定键的属性时

this.hashMap.get(fileName1).getId()

我得到了value = id2,它是为HashMapDataSet对象设置的最后一个id。

我试图在javascript中模仿getter和setter,如以下链接中所指定的: http://javascript.crockford.com/private.html

这是HashMapDataSet类

function HashMapDataSet(pId, pName, pType) {
var id = pId;
var name = pName;
var type = pType;

function getId1() {
return id;
}
function setId1(mId) {
id = mId;
}
....

this.getId = function () {
return getId1();
};

this.setId = function (id) {
setId1(id);
};

...
}

其中getId1,setId1是私有方法和 getId,setId是特权方法

我是javascript的新手,所以我无法将java对象与javascript相关联。请帮助。

3 个答案:

答案 0 :(得分:1)

我不太确定你在那里做什么,但是在javascript中你不需要所有这些java连线,因为该语言有内置的地图和列表。您的代码段在js

中可能如下所示
this.hashMap = {};
this.hashMapArrayList =[];
...
this.hashMapArrayList.push({id: id1, name: name1, type: type1});
...
this.hashMap.fileName1 = this.hashMapArrayList;

this.hashMapArrayList.push({id: id2, name: name2, type: type2 });
this.hashMap.fileName2 = this.hashMapArrayList;

答案 1 :(得分:0)

javascript-closure-loop问题很常见。

我会花很多时间:http://www.javascriptkata.com/2007/04/11/a-common-problem-with-the-powerful-javascript-closures/

问候。

答案 2 :(得分:0)

对于您不需要私有函数的类,您可以直接使用特权函数:

    function HashMapDataSet(pId, pName, pType)
    {
       var id = pId;
       var name = pName;
       var type = pType;

       this.getId = function ()
       {
          return id;
       };

       this.setId = function (pId)
       {
          id = pId;
       }
   }