为了账号安全,请及时绑定邮箱和手机立即绑定

Django:同一页面上的帖子表单和帖子列表

Django:同一页面上的帖子表单和帖子列表

白衣染霜花 2024-01-16 15:13:03
我创建了一个具有多个用户的网站,使用图像发布帖子并能够添加/删除朋友。因此,很容易为帖子列表创建两个不同的页面并创建一个新页面。但当然,当你可以在同一个地方阅读帖子并发布新帖子时,它看起来会更好。据我了解(学习 django 不到一个月),我无法将 2 个视图连接到同一个 url,所以我看到的最合乎逻辑的方法是将 2 个视图连接到一个视图中,我还尝试使用模板继承来渲染通过包含模板发布表单,但实际上它不起作用。下面你可以看到我的观点、帖子模型和模板。感谢您的关注。views.py:from braces.views import SelectRelatedMixinfrom . import modelsfrom django.views import genericfrom django.contrib.auth.mixins import LoginRequiredMixinclass PostList(SelectRelatedMixin, generic.ListView):    model = models.Post    select_related = ('user',)class CreatePost(LoginRequiredMixin, SelectRelatedMixin, generic.CreateView):    fields = ('post_message', 'post_image')    model = models.Post    select_related = ('user',)    def form_valid(self, form):        self.object = form.save(commit = False)        self.object.user = self.request.user        self.object.save()        return super().form_valid(form)models.py:import misakaclass Post(models.Model):    user = models.ForeignKey(User, on_delete = models.CASCADE, related_name = 'posts')    posted_at = models.DateTimeField(auto_now = True)    post_message = models.TextField()    message_html = models.TextField(editable = False)    post_image = models.ImageField(upload_to = 'postpics', blank = True)    def __str__(self):        return self.post_message    def save(self, *args, **kwargs):        self.message_html = misaka.html(self.post_message)        super().save(*args, **kwargs)    def get_absolute_url(self):        return reverse('posts:all')    class Meta:        ordering = ['-posted_at']        unique_together = ['user', 'post_message']urls.py:app_name = 'posts'urlpatterns = [    path('', views.PostList.as_view(), name = 'all'),    path('new/', views.CreatePost.as_view(), name = 'create'),]post_form.html(模板,允许创建新帖子,将在 post_list.html 中看到):
查看完整描述

3 回答

?
炎炎设计

TA贡献1808条经验 获得超4个赞

您可以将 post_create_form 与 post_list_view 放在同一页面上,无需为帖子创建创建单独的视图,但您需要创建用于编辑和删除的视图。您可以为所有这些视图提供具有不同 URL 的相同 HTML 页面。在 Class_Based_Views 中使用template_name = 'example/example.html',。我希望我能理解您的问题,如果不能进一步澄清为什么您不能将两个视图合并为一个。



查看完整回答
反对 回复 2024-01-16
?
千万里不及你

TA贡献1784条经验 获得超9个赞

def posts(request):

posts = Post.objects.all()


form = PostForm(request.POST or None, request.FILES or None)

if request.method == "POST":

    if form.is_valid():

       ...


context={

    'posts'         : page_obj,

    'create_or_update_post_form' : form,


}

return  render(request, 'post/posts.html',context)

您是否在基于类的视图中很难做到这一点?


查看完整回答
反对 回复 2024-01-16
?
慕容3067478

TA贡献1773条经验 获得超3个赞

您可以使用基于 django 类的视图轻松完成。


创建视图为

from django.views.generic import ListView

from django.views.generic.edit import CreateView


class ModelCreate(CreateView):

    model = ModelName

    fields = ['field1', 'field2']

    template_name = 'same_page.html'

    success_url = reverse_lazy('list_view')



class ModelList(CreateView, ListView):

    model = ModelName

    fields = ['field1', 'field2']

    paginate_by = 5

    template_name = 'same_page.html'


    def get_context_data(self, *args, **kwargs):

        context = super().get_context_data(*args, **kwargs)

        context['form'] = self.get_form()

        return context


    # If form post redirect to ModelCreate View

    def post(self, request, *args, **kwargs):

        return ModelCreate.as_view()(request)

应用程序/urls.py

from django.urls import path

from app import views


path('list', views.ModelList.as_view(), name='list_view'),

path('add', views.ModelCreate.as_view(), name='add_view'),

最后在 templates/same_page.html 中

<div class="row">

   <div class="col-sm-5">

      <form method="post" enctype="multipart/form-data">

         {% csrf_token %}

         {{form.as_p}}

         <button type="submit" value="submit" class="btn btn-primary btn-sm float-right">Submit</button>                              

       </form>

   </div>

   <div class="col-sm-5">

    {% if object_list %}

       {% for object in object_list %}

         <p>{{object.field1}}</p>

         <p>{{object.field2}}</p>

       {% endfor %}

    {% endif %}

   </div>

</div>

希望这可以帮助。


查看完整回答
反对 回复 2024-01-16
  • 3 回答
  • 0 关注
  • 117 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信