Бесконечная прокрутка позволяет загружать дополнительный контент и выполняет необходимые действия, когда страница находится близко к нижней части.
Следующий макет HTML показывает бесконечную прокрутку —
<div class = "page"> <div class = "page-content infinite-scroll" data-distance = "100"> ... </div> </div>
Вышеприведенный макет содержит следующие классы —
-
page-content infinite-scroll — используется для контейнера бесконечной прокрутки.
-
data-distance — этот атрибут позволяет вам настроить расстояние от нижней части страницы (в пикселях) для запуска события бесконечной прокрутки, и его значение по умолчанию составляет 50 пикселей.
page-content infinite-scroll — используется для контейнера бесконечной прокрутки.
data-distance — этот атрибут позволяет вам настроить расстояние от нижней части страницы (в пикселях) для запуска события бесконечной прокрутки, и его значение по умолчанию составляет 50 пикселей.
Если вы хотите использовать бесконечную прокрутку в верхней части страницы, вам нужно добавить дополнительный класс «infinite-scroll-top» в «page-content» —
<div class = "page"> <div class = "page-content infinite-scroll infinite-scroll-top"> ... </div> </div>
События бесконечной прокрутки
бесконечный — используется для запуска, когда прокрутка страницы достигает указанного расстояния до дна. Это будет целью div class = «page-content infinite-scroll» .
Существует два метода приложения, которые можно использовать с контейнером бесконечной прокрутки:
Чтобы добавить прослушиватель событий бесконечной прокрутки в указанный контейнер HTML, используйте следующий метод —
myApp.attachInfiniteScroll(container)
Вы можете удалить прослушиватель событий бесконечной прокрутки из указанного контейнера HTML, используя следующий метод —
myApp.detachInfiniteScroll(container)
Где параметры — обязательные параметры, используемые как HTMLElement или строка для контейнера бесконечной прокрутки.
пример
В следующем примере демонстрируется бесконечная прокрутка, которая загружает дополнительный контент, когда прокрутка страницы близка к нижней части.
<!DOCTYPE html> <html> <head> <meta name = "viewport" content = "width = device-width, initial-scale = 1, maximum-scale = 1, minimum-scale = 1, user-scalable = no, minimal-ui" /> <meta name="apple-mobile-web-app-capable" content="yes" /> <meta name = "apple-mobile-web-app-status-bar-style" content = "black" /> <title>infinite_scroll</title> <link rel = "stylesheet" href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.min.css" /> <link rel = "stylesheet" href = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/css/framework7.ios.colors.min.css" /> </head> <body> <div class = "views"> <div class = "view view-main"> <div class = "navbar"> <div class = "navbar-inner"> <div class = "left"> </div> <div class = "center sliding">Infinite Scroll</div> <div class = "right"> </div> </div> </div> <div class = "pages navbar-through"> <div data-page = "home" class = "page"> <div class = "page-content infinite-scroll"> <div class = "list-block"> <ul> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 1</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 2</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 3</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 4</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 5</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 6</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 7</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 8</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 9</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 10</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 11</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 12</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 13</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 14</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 15</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 16</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 17</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 18</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 19</div> </div> </li> <li class = "item-content"> <div class = "item-inner"> <div class = "item-title">Item 20</div> </div> </li> </ul> </div> <div class = "infinite-scroll-preloader"> <div class = "preloader"></div> </div> </div> </div> </div> </div> </div> <script type = "text/javascript" src = "https://cdnjs.cloudflare.com/ajax/libs/framework7/1.4.2/js/framework7.min.js"></script> <style> .infinite-scroll-preloader { margin-top:-20px; margin-bottom:10px; text-align:center; } .infinite-scroll-preloader .preloader { width:34px; height:34px; } </style> <script> var myApp = new Framework7(); var $$ = Dom7; // Loading flag var loading = false; // Last loaded index var lastIndex = $$('.list-block li').length; // Max items to load var maxItems = 60; // Append items per load var itemsPerLoad = 20; // Attach 'infinite' event handler $$('.infinite-scroll').on('infinite', function () { // Exit, if loading in progress if (loading) return; // Set loading flag loading = true; // Emulate 1s loading setTimeout(function () { // Reset loading flag loading = false; if (lastIndex >= maxItems) { // Nothing more to load, detach infinite scroll events to prevent unnecessary loadings myApp.detachInfiniteScroll($$('.infinite-scroll')); // Remove preloader $$('.infinite-scroll-preloader').remove(); return; } // Generate new items HTML var html = ''; for (var i = lastIndex + 1; i <= lastIndex + itemsPerLoad; i++) { html += '<li class = "item-content"> <div class = "item-inner"> <div class = "item-title"> Item ' + i + ' </div> </div> </li>'; } // Append new items $$('.list-block ul').append(html); // Update last loaded index lastIndex = $$('.list-block li').length; }, 1000); }); </script> </body> </html>
Выход
Давайте выполним следующие шаги, чтобы увидеть, как работает приведенный выше код —
Сохраните приведенный выше HTML-код в виде файла infinite_scroll.html в корневой папке вашего сервера.
Откройте этот HTML-файл как http: //localhost/infinite_scroll.html, и вывод отобразится, как показано ниже.
Пример позволяет загружать дополнительный контент, когда прокрутка вашей страницы достигает указанного расстояния до дна.