所以我有以下数组:
var hdr = ("name", "date", "start_time", "selling_item", "total_call",
"end_time", "ad_num", "area", "order_num");
//this data is returned from db
现在我想用适当的命名约定替换它,所以我这样做:
renameTableHdr(hdrs){
var handler = hdrs;
for(var a = 0; a<hdrs.length; a++){
// console.log(hdrs[a]);
var itm = "";
if(hdrs[a] === 'name'){
itm = "Name";
}
if(hdrs[a] === 'ad_num'){
itm = "Ad Number";
}
if(hdrs[a] === 'date'){
itm = "Date";
}
if(hdrs[a] === 'order_num'){
itm = "Order Number";
}
if(hdrs[a] === 'start_time'){
itm = "Start Time";
}
if(hdrs[a] === 'area'){
itm = "Area";
}
if(hdrs[a] === 'selling_item'){
itm = "Selling Item";
}
if(hdrs[a] === 'end_time'){
itm = "End Time";
}
if(hdrs[a] === 'total_call'){
itm = "Total Call";
}
if(handler.indexOf(hdrs[a]) >= 0){
handler.splice(handler.indexOf(hdrs[a]),1);
}
this.tempTblHdr.push(itm);
}
},
因此,如果我不进行拼接,则返回的数据正确或符合预期。但是通过拼接,效果并不理想。
无拼接结果
(9) ["Ad Number", "Date", "Order Number", "Start Time", "Name", "Area", "Selling Item", "End Time", "Total Call", __ob__: Observer]
带有接头
(5) ["Ad Number", "Order Number", "Name", "Selling Item", "Total Call", __ob__: Observer]
//other 4 data are missing
我正在从handler
中删除这些项目,因为它们是正确命名约定中所需要的主要数据,并且有可能被添加。我正在重命名它们,而没有涉及或更改其索引。我在正确地做splice
吗?
答案 0 :(得分:1)
从数组中删除项目时,应像这样向后循环
renameTableHdr(hdrs){
var handler = hdrs;
for(var a = hdrs.length - 1; a >= 0; a--){
// ...
}
}
答案 1 :(得分:1)
我将通过不更改或不使用for循环的方式,通过以下方式简化翻译:
function renameTableHdr(hdrs) {
// console.log(hdrs[a]);
const translate = {
name: 'Name',
ad_num: 'Ad Number',
date: 'Date',
order_num: 'Order Number',
start_time: 'Start Time',
area: 'Area',
selling_item: 'Selling Item',
end_time: 'End Time',
total_call: 'Total Call',
'things with spaces':'Translates fine'
};
return hdrs.map((item) => translate[item] || "");
}
console.log(
renameTableHdr([
'name',
'date',
'start_time',
'selling_item',
'total_call',
'end_time',
'ad_num',
'area',
'order_num',
'XXXXXXXXXXXXXXXXXXXXXXXXXX',
'things with spaces',
]),
);
答案 2 :(得分:1)
从数组中删除项目时,应向后进行。这样做的原因是,即使您删除了该项目,索引也一直在增长。
因此,如果我这样做:
let array = ["a", "b", "c", "d"];
for (let i = 0; i < array.length; i++) {
console.log(array.splice(i, 1));
}
它第一次进入时,i
等于0
,因此它求值array[0]
(因此元素"a"
)并将其从数组中删除。
在第二次迭代中,i
将是1
,并且由于我的数组现在是["b", "c", "d"]
,所以array[i]
将是"c"
。
跳过"b"
并删除"c"
之后,该数组将为["b", "d"]
。在第三次迭代中,i
将为2
,由于这是数组,因此2
大于array.length
,它将在那里停止。
如果您向后进行操作,则会先删除"d"
,然后删除"c"
,依此类推,这意味着它不会跳过任何内容。
由于您担心索引编制,因此只需从unsifht
开始添加项目即可。
renameTableHdr(hdrs){
var handler = hdrs;
for(var a = hdrs.length-1; a>=0; a--){
// console.log(hdrs[a]);
var itm = "";
if(hdrs[a] === 'name'){
itm = "Name";
}
if(hdrs[a] === 'ad_num'){
itm = "Ad Number";
}
if(hdrs[a] === 'date'){
itm = "Date";
}
if(hdrs[a] === 'order_num'){
itm = "Order Number";
}
if(hdrs[a] === 'start_time'){
itm = "Start Time";
}
if(hdrs[a] === 'area'){
itm = "Area";
}
if(hdrs[a] === 'selling_item'){
itm = "Selling Item";
}
if(hdrs[a] === 'end_time'){
itm = "End Time";
}
if(hdrs[a] === 'total_call'){
itm = "Total Call";
}
if(handler.indexOf(hdrs[a]) >= 0){
handler.splice(handler.indexOf(hdrs[a]),1);
}
this.tempTblHdr.unshift(itm);
}
},