如何像在轮播中一样通过特定索引获取未来项目和过去项目
How to get future items and past items by specific index like in a carousel
我正在尝试创建自定义轮播。
我坚持使用算法。
我需要通过特定索引获取未来和过去的项目。
旋转木马可以无限移动。
示例:
var exampleArray = [1,2,3,4,5,6,7,8,9];
切片(示例数组,0); -->> currentItem = [1], futureItems = [2,3,4,5], pastItems = [6,7,8,9]
切片(示例数组,4); -->> currentItem = [5], futureItems = [6,7,8,9], pastItems = [1,2,3,4]
切片(示例数组,7); -->> currentItem = [8], futureItems = [9,1,2,3], pastItems = [4,5,6,7]
您可以使用 this question 的解决方案之一(我喜欢@mickmackusa 的)来旋转数组以将所需的 currentItem
放到中间;那么你可以只取中间之前的切片为 pastItems
,中间元素为 currentItem
,中间之后的切片为 futureItems
:
const slicer = (arr, idx) => {
let len = arr.length;
let mid = Math.floor(len/2);
let rotated = arr.slice(0);
rotated = rotated.concat(rotated.splice(0, (mid + idx + 1) % len));
return [rotated.slice(0, mid), [rotated[mid]], rotated.slice(mid+1)]
}
const exampleArray = [1,2,3,4,5,6,7,8,9];
[pastItems, currentItem, futureItems] = slicer(exampleArray, 0);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);
[pastItems, currentItem, futureItems] = slicer(exampleArray, 4);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);
[pastItems, currentItem, futureItems] = slicer(exampleArray, 7);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);
我正在尝试创建自定义轮播。
我坚持使用算法。
我需要通过特定索引获取未来和过去的项目。
旋转木马可以无限移动。
示例: var exampleArray = [1,2,3,4,5,6,7,8,9];
切片(示例数组,0); -->> currentItem = [1], futureItems = [2,3,4,5], pastItems = [6,7,8,9]
切片(示例数组,4); -->> currentItem = [5], futureItems = [6,7,8,9], pastItems = [1,2,3,4]
切片(示例数组,7); -->> currentItem = [8], futureItems = [9,1,2,3], pastItems = [4,5,6,7]
您可以使用 this question 的解决方案之一(我喜欢@mickmackusa 的)来旋转数组以将所需的 currentItem
放到中间;那么你可以只取中间之前的切片为 pastItems
,中间元素为 currentItem
,中间之后的切片为 futureItems
:
const slicer = (arr, idx) => {
let len = arr.length;
let mid = Math.floor(len/2);
let rotated = arr.slice(0);
rotated = rotated.concat(rotated.splice(0, (mid + idx + 1) % len));
return [rotated.slice(0, mid), [rotated[mid]], rotated.slice(mid+1)]
}
const exampleArray = [1,2,3,4,5,6,7,8,9];
[pastItems, currentItem, futureItems] = slicer(exampleArray, 0);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);
[pastItems, currentItem, futureItems] = slicer(exampleArray, 4);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);
[pastItems, currentItem, futureItems] = slicer(exampleArray, 7);
console.log(pastItems);
console.log(currentItem);
console.log(futureItems);