• 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的相关知识,有兴趣的朋友可以关注本人微信公众号:幸福关中

  • 相关阅读:
    spring bean的三种管理方式·
    mybatis解决字段名和实体属性不相同
    python字符串格式化方法%s和format函数
    myeclipse配置springmvc教程
    2019ICPC南昌站
    浅谈可持久化线段树(主席树)
    2019CCPC厦门站总结
    牛客练习赛53 E-老瞎眼pk小鲜肉(思维+线段树+离线)
    2019牛客暑期多校训练营(第一场)A
    [The Preliminary Contest for ICPC Asia Nanjing 2019] L-Digit sum
  • 原文地址:https://www.cnblogs.com/xingfuggz/p/10231397.html
Copyright © 2020-2023  润新知