标签是一个对文章很好的管理功能,设置标签可以更快的显示文章的属性和进行筛选。
django没有内置的标签功能,其实也可以自己写,基本的方法就是在models中增加一个字段,或者设置一个外键,另建一个模型,然后注册admin,在后台进行填写和管理,在前端需要调用的时候,可以通过{{ post.tag }}变量模式进行调用
接下来,我们可以使用一个更方便的工具django-taggit,
from django.db import models
from taggit.managers import TaggableManager
class Food(models.Model):
# ... fields here
tags = TaggableManager()
此时,就可以使用django-taggit了,打开127.0.0.1/admin,可以看到Tags标签已经被注册到后台中了,可以进行管理了
注意:本人在使用django3对这个工具进行使用的时候,遇到了一些问题
1-在Post模型中,标签一栏无法正确显示,显示为None:
原因和方法:
django-taggit不能将TaggableManager()直接运用在list_diaplay中,所以,要在admin.py中进行一些改动:
@admin.register(Post)
class PostAdmin(admin.ModelAdmin):
list_display = ('title','slug','tag_list','author','post_updated','status')
list_filter = ('tags','post_create','status')
ordering = ('-post_create',)
def get_queryset(self, request):
return super().get_queryset(request).prefetch_related('tags')
def tag_list(self, obj):
return u",".join(o.name for o in obj.tags.all())
注册list_display时,要用自定义的tag_list,并在下方定义两个方法:get_queryset/tag_list,此为django-taggit文档说明,这样,在admin管理后台,方能看到正确的显示
2-前端调用,无法显示和查询到的问题:
在前端调用的时候,如果直接采取{{ post.tags }}的格式,将无法得到显示,应该使用:
{{ post.tags.all|join:", " }}
这样就能查询和使用了