我尝试过搜索这个问题,但大多数时候我看到了正则表达式模式,所以:
如何使用帖子名称自动填充我的博客模型 slug 字段,而无需自己填写
如何使用不带正则表达式的 slug 建立一个链接到单个帖子页面
所以您还没有发布代码,但假设您的模型如下所示:
class Post(models.Model):
title = models.CharField(max_length=100)
slug = models.SlugField(unique=True)
content = models.TextField()
如果您想预先填写标题中的
slug
,根据您想要执行的位置,您有几个选项:
Post
仅由员工用户创建:在管理员中预先填充Post
将在管理员之外创建:覆盖 .save()
方法prepopulated_fields
@admin.register(Post)
class PostAdmin(admin.ModelAdmin):
prepopulated_fields = {'slug': ('title',)}
创建帖子时,Django 将在您键入标题时自动更新 slug 字段。非常好的用户体验,但仅限于管理员...管理员之外
在前面的示例中,如果您要从控制台或其他页面创建帖子,则最终可能会得到一个空的 slug。在这种情况下,您可以通过重写模型的.save()
slugify
来快速确保 slug 已预先填充:class Post(models.Model):
title = models.CharField(max_length=100)
slug = models.SlugField(unique=True)
content = models.TextField()
def save(self, *args, **kwargs):
self.slug = self.slug or slugify(self.title)
super().save(*args, **kwargs)
slug 的链接帖子# urls.py
from django.urls import path
from your_blog import views
urlpatterns = [
path('posts/<slug:the_slug>/', views.post_detail_view, name='show_post'),
]
然后,在您的视图模块中您将看到一个视图:
# your_blog/views.py
from django.views.generic.detail import DetailView
class PostDetailView(DetailView):
model = Post
# This file should exist somewhere to render your page
template_name = 'your_blog/show_post.html'
# Should match the value after ':' from url <slug:the_slug>
slug_url_kwarg = 'the_slug'
# Should match the name of the slug field on the model
slug_field = 'slug' # DetailView's default value: optional
post_detail_view = PostDetailView.as_view()
您可以通过在 Python 中调用来链接到
Post
:
reverse('show_post', args=[the_post.slug])
或者在 Django 模板中:<a href="{% url 'show_post' the_post.slug %}">{{ the_post.title }}</a>
编辑:发布索引页面然后您可以添加索引页面,生成链接到所有帖子的列表:
# your_blog/views.py
from django.views.generic import ListView
class PostListView(ListView):
model = Post
# This file should exist somewhere to render your page
template_name = 'your_blog/list_post.html'
在视图模板中:
<!-- your_blog/list_post.html -->
<ul>
{% for the_post in object_list %}
<li>
<a href="{% url 'show_post' the_post.slug %}">{{ the_post.title }}</a>
</li>
{% endfor %}
</ul>
希望有帮助:)
嘿我们如何在这里使用图像,以及如何通过 slugs 显示图像