только центральные кнопки, в каком то количестве (например 4, страницы от 1 до 10, текущая 5, нужно показать, 3,4,5,6,7 или 4,5,6,7). Как такое сделать?
Показывай ) Что именно не получается?
Есть такой компонент. Ему передаю всякие данные и showButtons (сколько чисел показывать). Сейчас я просто ставлю массив всех страниц и проверяю вот так: page <= index + showButtons && page >= index - (showButtons - 2) но мне нужно что бы постоянно показывалось одинаковое количество страниц
Да может и не причем, есть такой вызов alert( arr.filter(inBetween(3, 6)) ); вот и думаю как в функции inBetween получить текущий элемент проверяемый arr.filter
const inBetween = (min, max) => (element, index, array) => {}
А почему оно так не одинаковое выводит?
если я нахожусь на 1 стр. то будет от 1 до какго то числа, если перехожу на вторую то от 2 до того же числа но + 1 перед ним. Я сейчас сделал что оно ставит одинаковое количество слева и справа если они есть, а нужно что бы было просто постоянно одинакогое количество. Например, 1-5 (актив. 1), потом 1-5(актив. 2), потом 1-5 (актив. 3), потом 2-6(актив. 3 или 4), ... , 5-10 (актив. 7 или 8) , и так до 5-10 (актив. 10)
const all = (...fns) => item => [...fns].every(fn => fn(item)) const moreThan = min => value => value > min const lessThan = max => value => value < max const inBetween = (min, max) => all(moreThan(min), lessThan(max)) array.filter(inBetween(1,100))
Так, сначала тебе нужно определеить в какой рейндж входит выбраная страница, потом вывести этот рейндж по-сути
Рандж определён, а вот как его придерживаться
Так, это похоже на реальную задачу, гляну вечером если не помогут тут в течение дня
вдруг кому будет интересно, решил это вот так: const changePagination = () => { let from = page - Math.floor(showButtons/2); let to = page + Math.round(showButtons/2); if ( from < 0 ) { to = to + Math.abs(from); to = to > allPage ? allPage : to; from = 0; } if ( to > allPage ) { from = from - (to - allPage); from = from < 0 ? 0 : from; to = allPage; } setPaggination(range(from, to)); };
по моему говнокод, но рабочий
Обсуждают сегодня