django-taggit模块是一个可重用的应用程序,它主要提供一个标签模型和一个管理器,可以轻松地向任意模型添加标签。
https://github.com/alex/django-taggit
目录
添加taggit到setting.py中的INSTALLED_APPS
python -m pip install django-taggit
INSTALL_APPS = [
#...
'taggit',
]
from taggit.managers import TaggableManager
class Post(models.Mocel):
#...
tags = TaggableManager()
标记管理器将允许您从Post对象中添加、检索和删除标记。
python manage.py makemigrations blog
python manage.py migrate
导入标签模型表单django-taggit,并将post_list视图更改为根据标签筛选帖子。视图最终是这样的。
def post_list(request,tag_slug=None):
? ? object_list = Post.published.all()
? ? tag = None
? ? if tag_slug:
? ? ? ? tag = get_object_or_404(Tag, slug=tag_slug)
? ? ? ? object_list = object_list.filter(tags__in=[tag])
? ? paginator = Paginator(object_list,3)
? ? page = request.GET.get('page')
? ? try:
? ? ? ? posts = paginator.page(page)
? ? except PageNotAnInteger:
? ? ? ? posts = paginator.page(1)
? ? except EmptyPage:
? ? ? ? posts = paginator.page(paginator.num_pages)
? ? template = "blog/post/list.html"
? ? context = {
? ? ? ? "page":page,
? ? ? ? "posts":posts,
? ? ? ? "tag":tag,
? ? }
? ? return render(request,template,context)
path("", views.post_list, name="post_list"),
path('tag/<slug:tag_slug>/',views.post_list, name='post_list_by_tag'),
两个路径都指向相同的视图,但是我们对它们的命名不同。 ?
第一种模式将调用不带任何可选参数的post_list视图,而第二种模式将调用带tag_slug参数的视图。这里使用一个slug路径转换器将参数匹配为一个小写字符串,其中包含ASCII字母或数字,以及连字符和下划线字符。
? ? {% if tag %}
? ? ? ? <h2>Posts tagged with "{{ tag.name }}"</h2>
? ? {% endif %}
如果tag不是None,显示正在过滤的tag名称。
? ? ? ? <p class="tags">
? ? ? ? ? ? Tags:
? ? ? ? ? ? {% for tag in post.tags.all %}
? ? ? ? ? ? ? ? <a href="{% url 'blog:post_list_by_tag' tag.slug %}">
? ? ? ? ? ? ? ? ? ? {{ tag.name }}
? ? ? ? ? ? ? ? </a>
? ? ? ? ? ? ? ? {% if not forloop.last %},{% endif %}
? ? ? ? ? ? {% endfor %}
? ? ? ? </p>
遍历一个帖子的所有标记,显示一个自定义链接到URL,以根据该标记过滤帖子。我们使用{% URL "blog:post_list_by_tag"标签构建URL。使用URL的名称和slug标记作为其参数。我们用逗号分隔标签。