Django 2.1, как использовать пользовательские функции для отображения контекста - PullRequest
0 голосов
/ 26 апреля 2019

У меня есть боковая панель, в которой отображаются популярные посты, упорядоченные по количеству их комментариев.

Часть содержимого сообщения отображается с использованием {{ post.message_html|truncatechars:60|safe }} в шаблоне.

Для получения popular_posts я использую context_processors.py:

def get_popular_posts(request):
    context = {}
    context["popular_posts"] = (
        Post.objects.all()
        .annotate(comments_count=Count("comments"))
        .order_by("-comments_count")[:3]
    )
    return context

Как можно обработать post.message_html некоторой пользовательской функцией (той же самой) для каждого из popular_posts? Где эта функция должна быть написана?

models.py:

class Post(models.Model):
    user = models.ForeignKey(User, related_name="posts", on_delete=models.CASCADE)
    created_at = models.DateTimeField(auto_now=True)
    message = models.TextField()
    message_html = models.TextField(editable=False)
    group = models.ForeignKey(
        Group, related_name="posts", null=True, blank=False, on_delete=models.CASCADE
    )

    def __str__(self):
        return self.message

    def save(self, *args, **kwargs):
        self.message_html = misaka.html(self.message)
        super().save(*args, **kwargs)

    def get_absolute_url(self):
        return reverse(
            "posts:single", kwargs={"username": self.user.username, "pk": self.pk}
        )

    class Meta:
        ordering = ["-created_at"]
        unique_together = ["user", "message"]

и вот мой шаблон .html, который я включаю в другой шаблон:

<div class="left-bar">
  <h4 style="text-align: center;">POPULAR POSTS:</h4>
  <hr>

  {% for post in popular_posts %}
    <div class="jumbotron">
      <a href="{% url 'posts:single' username=post.user.username pk=post.pk %}">{{ post.message_html|truncatechars:60|safe }}</a>
        <hr>
        <span class="text-muted popular">
          <p>comments: {{ post.comments.count }}</p>
          <p>author: {{ post.user.username }}</p>
        </span>
    </div>
  {% endfor %}

</div>

1 Ответ

1 голос
/ 26 апреля 2019

Для этой цели вы можете создать собственный тег шаблона или фильтр. документы .

Фильтр шаблона может использоваться как {{ post.message_html|truncatechars:60|safe|process_message }}

# /app/templatetags/utils.py

register = template.Library()

@register.filter(name='process_message')
def process_message(value):
    # do something
    return result  #return processed message

...