欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Django基于类的增删改查,简单逻辑都不用写

程序员文章站 2022-05-29 20:22:23
Django是Python中一个非常牛逼的web框架,他帮我们做了很多事,里边也提前封装了很多牛逼的功能,用起来简直不要太爽,在写网站的过程中,增删改查这几个基本的功能我们是经常会用到,Django把这系列复杂的逻辑性东西都封装成了方法,供我们直接使用,在使用过程中的体会是简单到令人发指,一个简单的 ......

django是python中一个非常牛逼的web框架,他帮我们做了很多事,里边也提前封装了很多牛逼的功能,用起来简直不要太爽,在写网站的过程中,增删改查这几个基本的功能我们是经常会用到,django把这系列复杂的逻辑性东西都封装成了方法,供我们直接使用,在使用过程中的体会是简单到令人发指,一个简单的例子给大家演示一下。

首先创建一个有多对一关系关联模型

我们假设有一个主题,主题下边会有很多内容,然后我们将主题和内容用多对一的foreignkey字段关联起来,如下:

# models.py

from django.db import models
from django.shortcuts import reverse

class topic(models.model):
    text = models.charfield('主题', max_length=100)
    date_added = models.datetimefield('添加时间', auto_now_add=true)

    class meta:
        ordering = ['-date_added']
        verbose_name_plural = "主题"

    def __str__(self):
        return self.text


class entry(models.model):
    topic = models.foreignkey(topic, on_delete=models.cascade, verbose_name="主题")
    text = models.textfield('具体笔记')
    date_added = models.datetimefield('添加时间', auto_now_add=true)

    class meta:
        ordering = ['-date_added']
        verbose_name_plural = "具体知识"

    def __str__(self):
        return self.text[:50] + "..."

在视图views.py中我们使用了django给我们提供的通用显示视图listview(通用列表视图),detailview(通用详情视图)来进行数据查询处理。

# views.py

from django.views.generic import listview, detailview  # 通用显示视图
from django.views.generic.edit import createview, deleteview, updateview   # 通用编辑视图
from . import models as md
from django.urls import  reverse_lazy  # 增删改成功后要跳转的链接方法引入

# 通用显示视图查询列表 listview
class topicslist(listview):
    model = md.topic  # 属于哪个模型
    # 指定显示的静态模板
    template_name = 'mysite/topics.html'   
     # 自定义上下文变量,我们最好自己设置,覆盖掉默认的上下文变量
    context_object_name = 'topics'  


# 通用显示视图查询列表的详情页面 detailview
class topicdetail(detailview):
    model = md.topic
    template_name = 'mysite/topic.html'

接上文,在增删改查的过程中,我们使用了django给我们提供的通用编辑视图来处理表单数据,createview(添加),updateview(更新),deleteview(修改),如下:

# views.py

class topicupdate(updateview):
     # 与通用显示视图一致,定义属于哪个模型
    model = md.topic  
    # 覆盖掉默认的视图模板,使用我们自定义的
    template_name = 'mysite/edit_topic.html'    
    # 允许编辑的字段
    fields = ['text']   
    # 修改成功后跳转的链接地址
    success_url = reverse_lazy('mysite:topics')    


class topicdelete(deleteview):
    model = md.topic
    template_name = 'mysite/del_topic.html'
    success_url = reverse_lazy('mysite:topics')


class entrycreate(createview):
    model = md.entry
    template_name = 'mysite/new_entry.html'
    fields = ['topic', 'text']
    success_url = reverse_lazy('mysite:topics')

接着在我们urls中定义链接,注意这里的urls.py文件位于我们的应用中,并不是在项目中的urls.py里,我们在项目中利用了include进行了url地址的分发,这样做的好处,请自行了解官方文档。

# urls.py

from django.urls import path
from . import views
from .views import topiccreate, topicupdate, topicdelete, entrycreate

app_name = 'mysite'
urlpatterns = [
    path('topics/', views.topicslist.as_view(), name='topics'),
    path('topics/<int:pk>/', views.topicdetail.as_view(), name='topic'),
    path('topic/add/', topiccreate.as_view(), name='topic-add'),
    path('topic/<int:pk>/', topicupdate.as_view(), name='topic-update'),
    path('topic/<int:pk>/delete/', topicdelete.as_view(), name='topic-delete'),

    path('entry/add/', entrycreate.as_view(), name='entry-add'),
]

最后来看看我们的在静态模板文件中如何调用

<!-- topics.html 中的调用代码 -->

 <a href="{% url 'mysite:topic-add' %}">添加主题</a>
    {% if topics %}
        {% for topic in topics %}
          <li><a href="{% url 'mysite:topic' topic.id %}" >{{ topic.text }}</a> </li>
              <a href="{% url 'mysite:topic-update' topic.id %}">修改</a>
            <a href="{% url 'mysite:topic-delete' topic.id %}">删除</a>
        {% endfor %}
        {% else %}
            <p>还没有任何主题</p>
    {% endif %}

<!-- topic.html 中的调用代码 -->

<a href="{% url 'mysite:entry-add' %}">添加内容</a>
    <h1>{{ topic }}</h1>
<!-- 请仔细体会我们这里用的 topic.entry_set.all 方法 -->
    {% for entry in topic.entry_set.all %}
        {{ entry.text }}
       <p>日期:{{ entry.date_added }}</p>
    {% endfor %}

其他几个静态模板调用方法几乎一样,只需要更换action的提交地址即可,留给大家的作业了

# new_topic.html

<form action="{% url 'mysite:topic-add' %}" method="post">
        {% csrf_token %}
       {{ form }}
   <input type="submit" class="btn btn-block" value="提交">
   </form>

还有笔记页面我只写了一个增加页面,其余几个留给大家练习,祝大家django学习更上一层楼。
创作不易,我会持续分享关于django的相关知识,有兴趣的朋友可以关注本人微信公众号:幸福关中