我创建了一个javaScript库,其中文档可以处理可变数量的<div class="gallery">
元素。
我想要定义一个多维数组,它存储每个现有galery的信息。
var gallery = new Array;
gallery = ['images','imageActive','width'];
for (var i=0;i<$('.gallery').length;i++) {
gallery[i]['images'] = $('.gallery:eq['+i+'] img').index();
gallery[i]['imageActive'] = 0;
gallery[i]['width'] = $('.gallery:eq['+i+'] li').css('width');
}
我的做法完全错了吗?阵列不适合这种情况吗?
答案 0 :(得分:2)
分配给对象{}
for (var i=0;i<$('.gallery').length;i++) {
gallery[i] = {};
gallery[i]['images'] = $('.gallery:eq['+i+'] img').index();
答案 1 :(得分:0)
gallery = new Array
将创建一个空数组。在访问任何属性之前,您需要先使用对象填充数组:
var gallery = [];
gallery = ['images','imageActive','width'];
for (var i=0;i<$('.gallery').length;i++) {
gallery.push({}); // increase length and add empty object
gallery[i]['images'] = $('.gallery:eq['+i+'] img').index();
gallery[i]['imageActive'] = 0;
gallery[i]['width'] = $('.gallery:eq['+i+'] li').css('width');
}
答案 2 :(得分:0)
首先,你的第一个作业(= new Array
)是完全没必要的,你用下一行覆盖它,你在那里用文字语法创建一个数组。
我认为你的意思是:
var gallery = [];
for (var i=0;i<$('.gallery').length;i++) {
gallery[i] = {
images: $('.gallery:eq['+i+'] img').index(),
imageActive: 0,
width: $('.gallery:eq['+i+'] li').css('width')
};
}
创建一个空白数组,然后在其中放入条目,其中每个条目都是一个对象(或“地图”或“字典”,我们在JavaScript中不使用术语“关联数组”以避免混淆,以及,数组)。每个对象都有images
,imageActive
和width
属性。
var gallery = $(".gallery").map(function() {
var entry = $(this);
return {
images: entry.find('img').index(),
imageActive: 0,
width: entry.find('li').css('width')
};
}).get();