zoukankan      html  css  js  c++  java
  • 利用Django提供的ModelForm增删改数据的方法

    那么我们这次就用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

    # 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>

    本文转载于:https://www.jb51.net/article/154090.htm

  • 相关阅读:
    【转】[Python小记] 通俗的理解闭包 闭包能帮我们做什么?
    【OCR技术系列之六】文本检测CTPN的代码实现
    002. Centos7安装mysql5.5.37
    044. asp.net主题之二为主题添加CSS样式和动态加载主题
    043. asp.net主题之一初识主题和皮肤
    042. asp.net使用缓存来提高母版页的访问性能
    041. asp.net中内容页访问母版页中的控件
    040. asp.netWeb中TreeView控件绑定XML文件
    039. asp.netWeb用户控件之七实现具有虚拟键盘的功能的用户控件
    038. asp.netWeb用户控件之六实现日期选择的用户控件
  • 原文地址:https://www.cnblogs.com/fuyuteng/p/14753908.html
Copyright © 2011-2022 走看看