我有一个来自下面代码的对象输出如何在js中设置索引从0开始?
Object
3: Object
id: 34
type: 0
var obj = {};
var edited = false;
for (var i = 0; i < $(".list").length; i++) {
var data_id = parseInt($(".list").eq(i).attr('data-id'));
var data_type = parseInt($(".list").eq(i).attr('data-type'));
if ((data_type != 0)) {
edited = true;
} else {
edited = false;
}
if (edited == true) {
obj[i] = {};
obj[i]['id'] = data_id;
obj[i]['type'] = data_type;
}
}
console.log(obj);
答案 0 :(得分:2)
需要更多jQuery?
var arr = $(".list").filter(function() {
return $(this).data('type') != 0;
}).map(function() {
return { id : $(this).data('id'), type : $(this).data('type') };
}).get();
答案 1 :(得分:1)
实际上如果你想从0开始,使用另一个变量而不是&#34; i&#34; (当你用它作为索引时,我认为是3)。
var obj = {};
var edited = false;
var obj_idx = 0;
for (var i = 0; i < $(".list").length; i++) {
var data_id = parseInt($(".list").eq(i).attr('data-id'));
var data_type = parseInt($(".list").eq(i).attr('data-type'));
if ((data_type != 0)) {
edited = true;
} else {
edited = false;
}
if (edited == true) {
obj[obj_idx] = {};
obj[obj_idx]['id'] = data_id;
obj[obj_idx]['type'] = data_type;
obj_idx += 1;
}
}
console.log(obj);
我认为这次obj会是这样的:
Object
0: Object
id: 34
type: 0
答案 2 :(得分:1)
你可以通过Array.prototype.push.call
将对象伪造为数组,这样你也可以获得副作用:obj.length
。它有点忍者和优雅:]
var obj = {};
var edited = false;
for (var i = 0; i < $(".list").length; i++) {
var data_id = parseInt($(".list").eq(i).attr('data-id'));
var data_type = parseInt($(".list").eq(i).attr('data-type'));
if ((data_type != 0)) {
edited = true;
} else {
edited = false;
}
if (edited == true) {
Array.prototype.push.call(obj, {id: data_id, type: data_type});
}
}
答案 3 :(得分:0)
我将举一个非常简单易读的示例。假设您有一个具有以下结构的对象:
Object
0: Object
key: 'some-key'
value: 'some-value'
1: Object
...
然后您可能要从中删除一个条目并重新索引整个内容,这就是我的操作方式:
// obj is Object from above
const reIndexed = Object.entries(obj).map((element, index) => {
if (parseInt(element[0] != index) {
element[0] = index.toString();
}
return element;
});