猿问

带范围的简单分页算法

function generatePageRange(currentPage, lastPage) {

    const delta = 2;


    const range = [];

    for (let i = Math.max(2, (currentPage - delta)); i <= Math.min((lastPage - 1), (currentPage + delta)); i += 1) {

        range.push(i);

    }


    if ((currentPage - delta) > 2) {

        range.unshift('...');

    }

    if ((currentPage + delta) < (lastPage - 1)) {

        range.push('...');

    }


    range.unshift(1);

    if (lastPage !== 1) range.push(lastPage);


    return range;

}

 console.log('Selected page ${i}:', generatePageRange(5, 10));

我有总页面、页面范围和当前页面。


电流输出 [1、“...”、3、4、5、6、7、“...”、10]


预期产出


总页数 = 10,范围 = 5


页码 1 => 1, 2, 3, ---, 10


页码 2 => 1,2,3, ---, 10


页码 3 => ---, 3,4,---,10


页码 4 => ---, 4,5,---,10


页码 10 => 1, ---, 8, 9,10


偶然的你
浏览 110回答 1
1回答

胡说叔叔

对于非动态方法,您可以将结果分为三个部分,其中不同的实际页面创建不同的数组。function getPagination(page, total) {&nbsp; &nbsp; if (page < 3) return [1, 2, 3, '...', total];&nbsp; &nbsp; if (page < total - 2) return ['...', page - 1, page, '...', total];&nbsp; &nbsp; return [1, '...', total - 2, total - 1, total];}for (let i = 1; i <= 10; i++) console.log(i, ':', ...getPagination(i, 10));.as-console-wrapper { max-height: 100% !important; top: 0; }
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答