当前位置:  开发笔记 > 编程语言 > 正文

Prototype.js和关联数组

如何解决《Prototype.js和关联数组》经验,为你挑选了1个好方法。

我有一个以下结构的关联数组(对象)

var menu = new Object('Submenu A','Submenu B','Submenu C','Submenu D');
menu['Submenu A']=new Object();
menu['Submenu A']['Option A']= 'foo blah text';
menu['Submenu A']['Option B']= 'blah more text';
menu['Submenu B']['Option A']= 'blah blah';
menu['Submenu B']['Option B']= 'texty text';
...
etc.

这是在for..in循环上迭代的,当使用原型时由于使用toJSON()和camelise()等方法扩展类而中断

我尝试过使用Prototype的.each方法但是它错误地报告菜单['子菜单A']是未定义的,它似乎找不到它下面定义的选项.

在原型中迭代关联数组的正确方法是什么?

进一步澄清(感谢目前为止的答案).我正在慢慢地将一个项目迁移到使用原型,但是它有大量的代码尚未与原型兼容.有问题的代码位于其他几个文件使用的库中.代码由函数initialize_menu调用并包含代码

for (var i=0; i < menu.length; i++) {
    populate_sub_menu(menu[i])
}

子菜单功能的结构如下

function populate_sub_menu(subMenu){
    for (var option in menu[subMenu]) {
        html+=menu[subMenu][option]+'html'+subMenu+option;
    }
}

我要删除有关获取html元素的代码以及与问题无关的代码.



1> Ates Goral..:

要创建没有属性的新对象,请使用:

var menu = new Object();

Object构造函数实际上接受一个可选参数.现在让我们来看看你有什么:

var menu = new Object('Submenu A','Submenu B','Submenu C','Submenu D');

只使用第一个参数('Submenu A')而忽略其他参数.但是,将字符串文字传递给Object构造函数会导致String返回一个新对象而不是一个Object对象.我猜测,这可能是原型each()正在起作用的原因(如果由于这个原因它真的失败了).

你提到"它错误地报告菜单['SubmenuA']是未定义的".你的问题有错字吗?您正在设置"子菜单A"属性,在"A"之前有一个空格,而您报告的错误似乎缺少空格.

您似乎也在设置对象属性方面走了很长的路.使用对象文字语法会更短,更不容易出错:

var menu = {
    "Submenu A": {
        "Option A": "foo blah text",
        "Option B": "blah more text"
    },
    "Submenu B": {
        "Option A": "blah blah",
        "Option B": "texty text"
    }
};

推荐阅读
手机用户2402852307
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有