您好,我目前想使用分页功能列出商店中的图片。我需要每次显示指定数量的图像,并允许循环在我指定的页码上停止。 (例如,每页30张图像,我需要第3页,我需要列出图像的第3页)。到目前为止,迭代所有文件,我只需要根据pageCount列出objectsPerPage

(GET / list / {storeid}?page = {pageNumber}&per_page = {perPage}

var shopId = event.shopkeeper + "/";
var objectsPerPage = event.perPage;
var pageCount = event.pageNumber;

var params = {
    Bucket: AWS_Bucket,
    Delimiter: '/',
    Prefix: shopId,
    MaxKeys: objectsPerPage
}; var dataContents = [];

function s3ListObjects() {
s3.listObjects(params, function(err, data) {
    if (err) {
        console.log("listS3Objects Error:", err);
    } else {
        var contents = data.Contents;
        dataContents = dataContents.concat(contents);
        if (data.IsTruncated) {
            params.Marker = contents[contents.length-1].Key;
            s3ListObjects(params, callback);
        } else {
            console.log(dataContents);
        }
    }
});
}

最佳答案

我最终做的一个解决方案是创建一个pageCounter变量,并将延续标记转换为整数值。然后,在通过提供页数循环文件时,此计数将增加。还构造了一个简单的if语句,以便当pageCount等于请求的页面时,它将控制台。注销数据。

var s3DataContents = [];
var pageCounter = 0;

function s3ListObjects() {
    s3.listObjectsV2(params, function(err, data) {
    if (err) {
        console.log("listS3Objects Error:", err);
    } else {
        if(data.IsTruncated) {
            if(pageCounter == page){
                s3DataContents = data.Contents;
                s3DataContents.forEach(function(content){
                    let dates = new Date(content.LastModified).toLocaleString();
                    let str = content.Key;
                    str = str.split(shopId).pop();
                    return console.log("name: " + str + ";" + " created: " + dates + ";" + " size: " + content.Size +  ";");
            });
            } else {
                //if more files then iterate through
                params.ContinuationToken = data.NextContinuationToken;
                s3ListObjects(params, callback);
                //convert string into integer value
                params.ContinuationToken = parseInt(pageCounter);
                pageCounter++;
            }
        } else {
            callback("Images not found " + err);
        }
    }
});

08-07 23:49