EnterSandman
@EnterSandman
Эникей

Как сделать jquery пагинацию по скроллу с очисткой?

Доброго времени суток.
Ищу плагин или реализацию слайдера по скролу, но не бесконечного
Нужна "пагинация", данные подгружаются с удаленого сервера допустим по 10 строк
по скроллу вверх/вниз нужно показать следующие/предыдущие 10 строк, а то что было выведено - убрать

всё что находил - грузит данные и добавляет к документу. может кто-то видел?
Спасибо
  • Вопрос задан
  • 2942 просмотра
Пригласить эксперта
Ответы на вопрос 2
IonDen
@IonDen
JavaScript developer. IonDen.com
Если убрать предыдущие 10 строк, то скроллить дальше будет некуда, не считаете? Может по этому нет реализаций подобного поведения по скроллу? В том то и суть подгрузки по скроллу, что новый контент добавляется к существующему, тем самым увеличивая область для прокрутки, в любой другой ситуации используются кнопочки, так как нельзя будет достоверно определить что мы доскроллили до нужного места.
Ответ написан
Комментировать
@stas3572
Я бы все делал таким образом:
<div class="overflow">
	<div class="wrapper">
		<div class="item">предыдущие 10 строк</div>
		<div class="item">10 строк видимые</div>
		<div class="item">следубщие 10 строк</div>
	</div>
</div>

где: .overflow и .item имеют одинаковый размер, .overflow имеет overflow:hidden, а .item - обертка для единицы загружаемых данных.

Логика следующая:
при старте загружаем 2 единицы данных - первые 10 строк и следующие 10, следующие 10 никто не видит. Дальше занимаемся «любовными утехами» с событием wheel над нашим блоком + проверяем и отмеряем положение .wrapper относительно верха страницы -> если понимаем что был скролл вниз, то соответственно «двигаем» .wrapper на одну высоту .item'а, т.е. эмулируем скролл, и кроме того загружаем следующие 10 строк, и «аппендим» еще один .item с этими данными в наш .wrapper. Если скролл вверх - то просто эмулируем скролл.

И я бы не советовал совсем уж удалять выведенные уже блоки, пусть будут скрыты - а иначе:
1) придется еще проверять количество .item'ов, и очищать первые (но это мелочь);
2) если была прокрутка вниз, на несколько .item'ов, первоначальные данные очистились, а затем прокрутка вверх - мало того что надо теперь очистить_низ+вставить_данные_вверх, надо еще как то вставлять те данные которые уже были в этом месте.

Да и к тому же - если не очищать, то сократите количество ajax-запросов (будут только на загрузку, а когда данных больше нет - дошел до дна и остается функционал только скролла). Скролл не принципиален, то и пользователям будет логичнее и вам проще все это повесить на кнопки вверх/вниз, в идеале надо делать и со скролом и с кнопками.

Как то так, извините если что-то непонятно, в голове у меня решение быстро нашлось, а вот формулировал я долго, если что - спрашивайте!)
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
23 нояб. 2024, в 01:31
1000 руб./за проект
23 нояб. 2024, в 00:16
2000 руб./за проект