Django在同一页面编辑关联对象的数据

问题描述:

在Django中,我们想在同一页面编辑关联对象的数据。如:
在博客的分类编辑页中,新建或者修改该分类下的文章。

代码如下:

from django.contrib import admin

from .models import Post, Category


# 在分类列表页面增加编辑文章的功能: 定义文章的Inline
class PostInline(admin.TabularInline):  # StackedInline样式不同
    # 要显示编辑的字段, 其中Post的category字段不需要设置,它默认的值就是当前编辑的分类。
    fields = ('title', 'desc')  
    extra = 0  # 控制额外多几个空白记录
    model = Post


# Register your models here.
@admin.register(Category)
class CategoryAdmin(admin.ModelAdmin):
    inlines = [PostInline, ]  # 添加文章的Inline
    list_display = ('name', 'status', 'is_nav', 'owner', 'created_time', 'post_count')
    fields = ('name', 'status', 'is_nav')

    # 展示该分类下有多少文章
    def post_count(self, obj):
        return obj.post_set.count()

    post_count.short_description = '文章数量'

    def save_model(self, request, obj, form, change):
        obj.owner = request.user
        return super(CategoryAdmin, self).save_model(request, obj, form, change)

	# 修改关联对象Post的数据
    def save_formset(self, request, form, formset, change):
        """ 修改关联对象Post的数据 """
        instances = formset.save(commit=False)
        for instance in instances:
            if not hasattr(instance, 'owner'):  # 防止误修改其他文章的作者
                instance.owner = request.user  # 给Post的owner字段赋值
                instance.save()
        formset.save_m2m()

代码分析:
因为我们的文章作者默认是设置为当前登录的用户,所以需要在CategoryAdmin中修改关联对象Post的数据,即给文章的作者赋值。

 instance.owner = request.user  # 给Post的owner字段赋值
 instance.save()

结果如下:

分类的编辑页面:
分类编辑页面

在 中,可以通过使用多个模型和视图来实现在同一页面中展示多张表的数据。以下是一些步骤: 1. 定义多个模型:在 models.py 文件中定义需要展示的多个模型,每个模型对应一个表格。 2. 创建视图:在 views.py 文件中创建视图函数,该函数可以使用多个模型的查询结果,将它们组合在一起,传递给模板。 3. 定义模板:在模板中,可以使用 Django 模板语言来展示多个模型的数据。可以使用 for 循环语句来遍历每一个模型的查询结果,并将其展示在页面上。 4. 实现查询功能:可以通过表单等方式,向视图函数传递查询关键词,然后在视图函数中进行查询,并将查询结果传递给模板展示。 示例代码: models.py: ```python from django.db import models class Book(models.Model): title = models.CharField(max_length=100) author = models.CharField(max_length=50) price = models.DecimalField(max_digits=6, decimal_places=2) class Magazine(models.Model): name = models.CharField(max_length=100) publisher = models.CharField(max_length=50) price = models.DecimalField(max_digits=6, decimal_places=2) ``` views.py: ```python from django.shortcuts import render from .models import Book, Magazine def book_magazine_view(request): books = Book.objects.all() magazines = Magazine.objects.all() return render(request, 'book_magazine.html', {'books': books, 'magazines': magazines}) ``` book_magazine.html: ```html <h1>Books</h1> <table> <thead> <tr> <th>Title</th> <th>Author</th> <th>Price</th> </tr> </thead> <tbody> {% for book in books %} <tr> <td>{{ book.title }}</td> <td>{{ book.author }}</td> <td>{{ book.price }}</td> </tr> {% endfor %} </tbody> </table> <h1>Magazines</h1> <table> <thead> <tr> <th>Name</th> <th>Publisher</th> <th>Price</th> </tr> </thead> <tbody> {% for magazine in magazines %} <tr> <td>{{ magazine.name }}</td> <td>{{ magazine.publisher }}</td> <td>{{ magazine.price }}</td> </tr> {% endfor %} </tbody> </table> ``` 在这个示例中,我们定义了两个模型 `Book` 和 `Magazine`,在视图函数 `book_magazine_view` 中查询了它们的数据,并将它们传递给模板 `book_magazine.html`。在模板中,我们使用了两个不同的表格来展示每个模型的数据,并且使用了 for 循环语句来遍历查询结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值