Array.push 在使用内部地图功能时更新自身
Array.push updates itself while using inside map function
这里我使用了两个新数组来捕获 URL 和文件名值。当我在控制台上查看它时,每次都会得到不同的值,比如数组被以前的值覆盖,我做错了什么吗?
downLoadFilesAsZip = async(item) => {
for (const index in item.docLinks) {
let urlArr=[];
let fileNameArr = [];
const url = item.docLinks[index];
let linkParts = url.split("?");
let filename = linkParts[0].substring(linkParts[0].lastIndexOf('/')+1);
urlArr.push(url);
fileNameArr.push(filename);
}
}
downLoadAllAsZip = () => {
{
this.state.docGroups.length !== 0 && this.state.docGroups.map((item) => {
if(item.docLinks !== null && item.docLinks.length > 0){
return(
this.downLoadFilesAsZip(item)
);
}
})
}
}
跟随循环。每次循环运行时,您都在设置空数组。
let urlArr=[];
let fileNameArr = [];
将其带出 for 循环。
在 for 循环外声明数组(导入后)有助于更新每个值,
对于 .tsx 文件答案是这样的
type urlArr = any[];
type fileNameArr = any[];
let urlArr=[];
let fileNameArr = [];
这里我使用了两个新数组来捕获 URL 和文件名值。当我在控制台上查看它时,每次都会得到不同的值,比如数组被以前的值覆盖,我做错了什么吗?
downLoadFilesAsZip = async(item) => {
for (const index in item.docLinks) {
let urlArr=[];
let fileNameArr = [];
const url = item.docLinks[index];
let linkParts = url.split("?");
let filename = linkParts[0].substring(linkParts[0].lastIndexOf('/')+1);
urlArr.push(url);
fileNameArr.push(filename);
}
}
downLoadAllAsZip = () => {
{
this.state.docGroups.length !== 0 && this.state.docGroups.map((item) => {
if(item.docLinks !== null && item.docLinks.length > 0){
return(
this.downLoadFilesAsZip(item)
);
}
})
}
}
跟随循环。每次循环运行时,您都在设置空数组。
let urlArr=[];
let fileNameArr = [];
将其带出 for 循环。
在 for 循环外声明数组(导入后)有助于更新每个值, 对于 .tsx 文件答案是这样的
type urlArr = any[];
type fileNameArr = any[];
let urlArr=[];
let fileNameArr = [];