更新视图——基于函数的视图 Django(可以基于视图定义新的视图)

网友投稿 319 2022-08-26


更新视图——基于函数的视图 Django(可以基于视图定义新的视图)

作者:海拥

更新视图是指一种视图(逻辑),用于从数据库中更新表的特定实例,并提供一些额外的细节。它用于更新数据库中的条目,例如,更新 geeksforgeeks 上的文章。所以更新视图必须在表单中显示旧数据,并让用户只从那里更新数据。Django 为更新视图提供了非凡的支持,但让我们检查一下它是如何通过基于函数的视图手动完成的。本文围绕更新视图展开,其中涉及Django Forms、Django Models等概念。

对于更新视图,我们需要一个包含一些模型和多个实例的项目,它们将被显示。基本上,更新视图是详细视图和创建视图的组合。

Django 更新视图——基于函数的视图

如何使用示例创建和使用更新视图的说明。考虑一个名为 geeksforgeeks 的项目,它有一个名为 geeks 的应用程序。

在你有一个项目和一个应用程序之后,让我们创建一个模型,我们将通过我们的视图创建它的实例。在 geeks/models.py 中,

创建此模型后,我们需要运行两个命令才能为其创建数据库。

Python manage.py makemigrationsPython manage.py migrate

现在让我们使用 shell 创建这个模型的一些实例,运行表单 bash,

Python manage.py shell

输入以下命令

>>> from geeks.models import GeeksModel>>> GeeksModel.objects.create( title="title1", description="description1").save()>>> GeeksModel.objects.create( title="title2", description="description2").save()>>> GeeksModel.objects.create( title="title2", description="description2").save()

现在我们已经为后端做好了一切准备。验证是否已从**创建实例

现在我们将为这个模型创建一个 Django ModelForm,在 geeks 文件夹中创建文件 forms.py,

from django import formsfrom .models import GeeksModel# 创建表单class GeeksForm(forms.ModelForm): # 创建 meta 类 class Meta: # 指定要使用的模型 model = GeeksModel # 指定要使用的字段 fields = [ "title", "description"]

对于 Update_view,需要一些标识来获取模型的特定实例。通常它是唯一的主键,例如id。要指定这个标识,我们需要在 urls.py 中定义它。转到geeks/urls.py,

from django.urls import path# 从视图导入 views..pyfrom .views import update_view, detail_viewurlpatterns = [ path('/', detail_view ), path('/update', update_view ),]

让我们用解释创建这些视图。在 geeks/views.py 中,

from django.shortcuts import (get_object_or_404, render, HttpResponseRedirect)# 表格的相对导入from .models import GeeksModelfrom .forms import GeeksForm# 更新后会重定向到 detail_Viewdef detail_view(request, id): # 以字段名称为键的初始数据字典 context ={} # 在初始化期间添加字典 context["data"] = GeeksModel.objects.get(id = id) return render(request, "detail_view.html", context)# 更新视图以获取详细信息def update_view(request, id): # 以字段名称为键的初始数据字典 context ={} # 获取与传递的 id 相关的对象 obj = get_object_or_404(GeeksModel, id = id) # 将对象作为实例传递给表单 form = GeeksForm(request.POST or None, instance = obj) # 保存表单中的数据并重定向到 detail_view if form.is_valid(): form.save() return HttpResponseRedirect("/"+id) # 将表单字典添加到上下文 context["form"] = form return render(request, "update_view.html", context)

现在在模板文件夹中创建以下模板, 在 geeks/templates/update_view.html 中,

{% csrf_token %} {{ form.as_p }}

在 geeks/templates/detail_view.html 中,

{{ data.title }}
{{ data.description }}

让我们检查一下是否一切正常,访问**http://localhost:8000/1/update**。

在这里您可以看到已经从实例中填充数据的表单,现在可以编辑这些数据并轻松更新它,让我们检查一下


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Spring MVC如何实现接口Controller定义控制器
下一篇:Numpy中的四个小技巧(numpy常用功能总结)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~