利用Django提供的ModelForm增删改数据的方法
作者:幸福关中人 时间:2021-02-04 04:13:00
上一篇我们写了Django基于类如何增删改数据的方法,方法虽然简单,但新手可能对其原理不是很清楚,那么我们这次就用Django提供的ModelForm方法来实现增删改数据,这是一种基于现有模型的增删改方法。
一个简单的例子加以说明,前提是你已经具备Django创建项目应用的基本知识:
01.首先创建一个简单的模型,模型只有三个文本字段,标题 title , 内容 text , 添加日期 date_added ,如下:
# models.py
from django.db import models
from django.utils import timezone
class Article(models.Model):
title = models.CharField('标题', max_length=100)
text = models.TextField('内容')
date_added = models.DateTimeField(default=timezone.now)
def __str__(self):
return self.title
创建完模型别忘了生成数据库, makemigrations 方法(生成迁移文件), migrate (迁移到数据库) 。
02.在项目中创建一个 form.py 的文件,我这里的项目名称是 app1 ,在其中创建继承一个 ModelForm 的表单类 ArticleForm ,他的子类中包含很多内置的方法,我都都可以对其覆盖,有兴趣的同学可以看官方文档,讲的非常详细。
文档地址: https://docs.djangoproject.com/zh-hans/2.1/topics/forms/modelforms/#django.forms.ModelForm ,
# form.py
from django.forms import ModelForm
from .models import Article
class ArticleForm(ModelForm): # 继承ModelForm类
class Meta:
model = Article # 具体要操作那个模型
fields = ['title', 'text', 'date_added'] # 允许编辑的字段
03.创建我们视图函数,开始增删改
# views.py
from django.shortcuts import render, redirect
from .models import Article
from .form import ArticleForm
def articles(request):
# 查询列表页面,获取Article的所有信息
articles = Article.objects.all()
return render(request, 'app1/articles.html', {'articles':articles})
# 与其对应的url,在应用中的urls.py中设置
path('article/', views.articles, name='article'),
# 添加页面
def new_article(request):
# 如果不是POST方法访问
if request.method != 'POST':
# 创建一个空表单在页面显示
form = ArticleForm()
else:
# 否则为POST方式
# request.POST方法,将会获取到表单中我们输入的数据
new_article = ArticleForm(request.POST)
# 验证其合法性,使用is_valid()方法
if new_article.is_valid():
# 验证通过,使用save()方法保存数据
new_article.save()
# 保存成功,使用redirect()跳转到指定页面
return redirect('app1:article')
return render(request, 'app1/new_article.html', {'form':form})
# 编辑修改页面
def edit_article(request, article_id):
# 查询到指定的数据
article = Article.objects.get(id=article_id)
if request.method != 'POST':
# 如果不是post,创建一个表单,并用instance=article当前数据填充表单
form = ArticleForm(instance=article)
else:
# 如果是post,instance=article当前数据填充表单,并用data=request.POST获取到表单里的内容
form = ArticleForm(instance=article, data=request.POST)
form.save() # 保存
if form.is_valid(): # 验证
return redirect('app1:article') # 成功跳转
return render(request, 'app1/edit_article.html', {'form':form,'article':article})
# 删除页面
def del_article(request, article_id):
article = Article.objects.get(id=article_id)
if request.method == 'POST':
article.delete()
return redirect('app1:article')
return render(request, 'app1/del_article.html', {'article': article})
05.设置所有视图的url
# 列表
path('article/', views.articles, name='article'),
# 添加
path('new_article/', views.new_article, name='new_article'),
# 修改
path('edit_article/<int:article_id>/', views.edit_article, name='edit_article'),
# 删除
path('del_article/<int:article_id>/', views.del_article, name='del_article'),
06.静态页面调用
# articles.html
<a href="{% url 'app1:new_article' %}" rel="external nofollow" >添加</a>
{% for article in articles %}
<h1>{{ article.title }}</h1>
<p>{{ article.text }}</p>
<a href="{% url 'app1:edit_article' article.id %}" rel="external nofollow" >修改</a>
<a href="{% url 'app1:del_article' article.id %}" rel="external nofollow" >删除</a>
{% endfor %}
# new_article.html
<form action="{% url 'app1:new_article' %}" method="post">
{% csrf_token %}
{{ form.as_ul }}
<input type="submit" value="提交">
</form>
07.其他两个修改和删除页面的模板中调用方法与 new_article.html 中的方法一样,只需要更换 action 中的 url 即可。
来源:https://www.jianshu.com/p/1c4aac134a1e
标签:Django,ModelForm,增删改


猜你喜欢
Mysql双主搭建的方法步骤
2024-01-29 05:57:50

python嵌套try...except如何使用详解
2022-06-21 16:53:00
在ASP.NET 2.0中操作数据之二十七:创建自定义排序用户界面
2023-06-25 21:01:05

js中各浏览器中鼠标按键值的差异
2024-05-05 09:15:28

python 遍历pd.Series的index和value
2021-12-27 15:50:42
driver = webdriver.Chrome()报错问题及解决
2023-04-09 21:03:16

使用Python制作表情包实现换脸功能
2022-01-14 09:10:18

多线程爬虫批量下载pcgame图片url 保存为xml的实现代码
2021-04-12 15:06:27
php获取qq用户昵称和在线状态(实例分析)
2023-11-14 11:19:22
Python代码调试的几种方法总结
2022-06-14 18:21:27

Python设计模式之观察者模式简单示例
2023-07-12 04:36:06

django 使用全局搜索功能的实例详解
2023-01-26 05:56:56
Pytorch十九种损失函数的使用详解
2021-07-19 22:23:07

python deque模块简单使用代码实例
2022-10-16 04:08:12
js找出5个数中最大的一个数和倒数第二大的数实现方法示例小结
2024-04-28 09:49:10
C#实现根据实体类自动创建数据库表
2024-01-12 13:23:29
python 存储json数据的操作
2022-10-02 13:14:14

python如何利用cv2.rectangle()绘制矩形框
2021-03-14 10:12:51
根据表中数据生成insert语句的存储过程
2008-11-10 12:13:00
MySQL旧版本升级为新版本
2009-02-26 15:44:00