<MyRusakov.ru />

Профессиональная Web-разработка. Дизайн, код и автоматизация

Профессиональная Web-разработка. Дизайн, код и автоматизация

Это очень подробный курс из разряда "всё включено". Разбираются следующие темы: HTML, CSS, SCSS, JavaScript, PHP, SQL, Laravel, Nginx, PostCSS, npm, Vite, Vitest, Composer, PHPUnit, Prettier, Stylelint, ESLint, Pint, Larastan, Git, Agile, Scrum, Docker, Supervisord, Figma, Stitch AI, Confluence, Jira.

Рассчитан и на новичков, и на тех, кто уже знаком с основами, но хочет освоить полный цикл разработки.

Помимо самой теории, Вы увидите пример создания Web-проекта на 20 000 строк кода: от идеи и документации на Confluence через планирование на Jira, fullstack-разработку до деплоя на VPS.

Помимо уроков, курс содержит упражнения для закрепления знаний и финальное тестирование. А ещё Вы получите 5 полноценных Бонусных курсов: «GitLab под ключ», «Вёрстка сайта с нуля 2.0», «JavaScript с Нуля до Гуру 2.0», «PHP и MySQL с Нуля до Гуру 3.0» и «Laravel от А до Я».

Подробнее
Подписка

Подпишитесь на мой канал на YouTube, где я регулярно публикую новые видео.

YouTube Подписаться

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Какая тема Вас интересует больше?

Простая пагинация на Python и Flask

Простая пагинация на Python и Flask

Здравствуйте! Как известно, скорость загрузки сайта влияет на пользовательский опыт. Чем больше время загрузки, тем меньше посетителей на сайте. Одним из способов увеличения быстродействия является уменьшение количества выводимых данных или же пагинация. В сегодняшней статье мы рассмотрим, как создавать пагинацию на web сайте, реализованном на Python и Flask.

app.py


from flask import Flask, request, render_template_string

app = Flask(__name__)

@app.route('/')
def index():
    # Создаем список из 200 элементов
    items = [f"Item {i+1}" for i in range(200)]

    # Получаем текущую страницу из параметров запроса, по умолчанию страница 1
    page = request.args.get('page', 1, type=int)

    # Устанавливаем количество элементов на одной странице
    per_page = 20

    # Общее количество элементов
    total_items = len(items)

    # Общее количество страниц (округляем вверх)
    total_pages = (total_items + per_page - 1) // per_page

    # Определяем начальный и конечный индекс для текущей страницы
    start = (page - 1) * per_page
    end = start + per_page

    # Получаем элементы для текущей страницы
    current_items = items[start:end]

    # Шаблон HTML для отображения списка с пагинацией
    html_template = """
    <!doctype html>
    <html lang="en">
      <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
        <title>List of Items with Pagination</title>
      </head>
      <body>
        <div class="container">
          <h1>List of 200 Items</h1>
          <ul>
            {% for item in current_items %}
              <li>{{ item }}</li>
            {% endfor %}
          </ul>
          <div>
            <!-- Ссылка на предыдущую страницу, если это не первая страница -->
            {% if page > 1 %}
              <a href="/?page={{ page - 1 }}">Previous</a>
            {% endif %}
            <!-- Текущая страница и общее количество страниц -->
            Page {{ page }} of {{ total_pages }}
            <!-- Ссылка на следующую страницу, если это не последняя страница -->
            {% if page < total_pages %}
              <a href="/?page={{ page + 1 }}">Next</a>
            {% endif %}
          </div>
        </div>
      </body>
    </html>
    """

    # Возвращаем HTML-шаблон с переданными параметрами
    return render_template_string(html_template, current_items=current_items, page=page, total_pages=total_pages)

if __name__ == '__main__':
    # Запускаем приложение Flask в режиме отладки
    app.run(debug=True)


Таким образом, создание пагинации позволило сократить объем данных, выводимых на странице. А для большего погружения в динамическую генерацию страниц рекомендую курс Программирование на Python с Нуля до Гуру.

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (https://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: https://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: https://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (0):

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.