Как сделать счетчик закладок для каждого пользователя
Сделал систему закладок как в статье , всё работает прекрасно, но у меня на сайте в панели меню есть кнопка избранного, где отображается сколько статей добавил в избранное пользователь, как сделать так, что бы он обновлялся так же как общий счетчик в статье
до нажатия на кнопку добавить в избранное
код меню (храниться в base шаблоне и подключается {% extends "main/base.html" %})
- <nav>
- <a href="/" style="color: inherit; text-decoration: none;">
- <picture>
- <source type="image/svg+xml" + srcset="{% static 'icons/article-white-18dp.svg' %}">
- <img src="{% static 'icons/article-white-18dp.svg' %}" width="16" height="16">
- </picture>
- <span class="body-2" style="color: inherit;">Статьи</span>
- <span class="counter">{{ article_count.count }}</span>
- </a>
- <a href="{% url 'post_favourite_list' %}" style="color: inherit; text-decoration: none;">
- <picture>
- <source type="image/svg+xml" + srcset="{% static 'icons/favorite-white-18dp.svg' %}">
- <img src="{% static 'icons/favorite-white-18dp.svg' %}" width="16" height="16">
- </picture>
- <span class="body-2">Избранное</span>
- <span class="counter" data-count="bookmark">{{ request.user.bookmarkarticle_set.all.count }}</span>
- </a>
- </nav>
жс код аякса
- function to_bookmarks()
- {
- var current = $(this);
- var type = current.data('type');
- var pk = current.data('id');
- var action = current.data('action');
- $.ajax({
- url : "/api/" + type + "/" + pk + "/" + action + "/",
- type : 'POST',
- data : { 'obj' : pk },
- success : function (json) {
- current.find("[data-count='" + action + "']").text(json.count);
- }
- });
- return false;
- }
- // Подключение обработчика
- $(function() {
- $('[data-action="bookmark"]').click(to_bookmarks);
- });
код кнопки "добавить в избранное" в статье
- <a data-id="{{ post.id }}" data-type="article" data-action="bookmark" title="Избранное">
- <button type="button" class="btn btn-danger" style="margin-top: 20px ">
- {% if post.bookmarkarticle_set.all|user_in:user %}
- <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor"
- class="bi bi-heart-fill" viewBox="0 0 16 16">
- <path fill-rule="evenodd"
- d="M8 1.314C12.438-3.248 23.534 4.735 8 15-7.534 4.736 3.562-3.248 8 1.314z"></path>
- </svg>
- {% else %}
- <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor"
- class="bi bi-heart-fill" viewBox="0 0 16 16">
- <path fill-rule="evenodd"
- d="M8 1.314C12.438-3.248 23.534 4.735 8 15-7.534 4.736 3.562-3.248 8 1.314z"></path>
- </svg>
- {% endif %}
- <span data-count="bookmark">{{ post.get_bookmark_count }}</span>
- </button>
- </a>
Вам это нравится? Поделитесь в социальных сетях!
Комментарии
Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Пожалуйста, авторизуйтесь или зарегистрируйтесь
- Последние комментарии
- AK1 апреля 2025 г. 11:41Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
- VP9 марта 2025 г. 16:14Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
- ИМ22 ноября 2024 г. 21:51Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
- Сейчас обсуждают на форуме
- МА1 апреля 2025 г. 16:210ff763fe-4e50-455d-a3a6-5699c243b1a5_17_44_22_1.xml
- f15 февраля 2025 г. 13:46Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
- Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
- Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
Скорее всего current не находит, смотрите, что в консоле браузера вываливает. Наверняка там есть ошибки.