利用Django提供的ModelForm增删改数据

上一篇我们写了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' %}">添加</a>
    {% for article in articles %}
        <h1>{{ article.title }}</h1>
        <p>{{ article.text }}</p>
        <a href="{% url 'app1:edit_article' article.id %}">修改</a>
        <a href="{% url 'app1:del_article' article.id %}">删除</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即可。

创作不易,我会持续分享关于Django的相关知识,有兴趣的朋友可以关注本人微信公众号:幸福关中, 如果您觉得不错的话,打赏以下小编,小编会更有动力分享更多关于Django方面的知识,欢迎大家加小编微信交流Django知识,备注Django,小编微信:xingfuguanzhong

原文地址:https://www.cnblogs.com/xingfuggz/p/10231379.html