经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Django » 查看文章
Django基于类的增删改查,简单逻辑都不用写
来源:cnblogs  作者:幸福关中  时间:2019/1/7 9:48:29  对本文有异议

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

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

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

  1. # models.pyfrom django.db import modelsfrom django.shortcuts import reverseclass Topic(models.Model):
  2.     text = models.CharField('主题', max_length=100)
  3.     date_added = models.DateTimeField('添加时间', auto_now_add=True)class Meta:
  4.         ordering = ['-date_added']
  5.         verbose_name_plural = "主题"def __str__(self):return self.textclass Entry(models.Model):
  6.     topic = models.ForeignKey(Topic, on_delete=models.CASCADE, verbose_name="主题")
  7.     text = models.TextField('具体笔记')
  8.     date_added = models.DateTimeField('添加时间', auto_now_add=True)class Meta:
  9.         ordering = ['-date_added']
  10.         verbose_name_plural = "具体知识"def __str__(self):return self.text[:50] + "..."

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

  1. # views.pyfrom django.views.generic import ListView, DetailView  # 通用显示视图from django.views.generic.edit import CreateView, DeleteView, UpdateView   # 通用编辑视图from . import models as mdfrom django.urls import  reverse_lazy  # 增删改成功后要跳转的链接方法引入# 通用显示视图查询列表 ListViewclass TopicsList(ListView):
  2.     model = md.Topic  # 属于哪个模型# 指定显示的静态模板template_name = 'mysite/topics.html'   
  3.      # 自定义上下文变量,我们最好自己设置,覆盖掉默认的上下文变量context_object_name = 'topics'  # 通用显示视图查询列表的详情页面 DetailViewclass TopicDetail(DetailView):
  4.     model = md.Topic
  5.     template_name = 'mysite/topic.html'

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

  1. # views.pyclass TopicUpdate(UpdateView):     # 与通用显示视图一致,定义属于哪个模型model = md.Topic  # 覆盖掉默认的视图模板,使用我们自定义的template_name = 'mysite/edit_topic.html'    # 允许编辑的字段fields = ['text']   # 修改成功后跳转的链接地址success_url = reverse_lazy('mysite:topics')    
  2.  
  3.  
  4. class TopicDelete(DeleteView):
  5.     model = md.Topic
  6.     template_name = 'mysite/del_topic.html'success_url = reverse_lazy('mysite:topics')class EntryCreate(CreateView):
  7.     model = md.Entry
  8.     template_name = 'mysite/new_entry.html'fields = ['topic', 'text']
  9.     success_url = reverse_lazy('mysite:topics')

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

  1. # urls.pyfrom django.urls import pathfrom . import viewsfrom .views import TopicCreate, TopicUpdate, TopicDelete, EntryCreate
  2.  
  3. app_name = 'mysite'urlpatterns = [
  4.     path('topics/', views.TopicsList.as_view(), name='topics'),
  5.     path('topics/<int:pk>/', views.TopicDetail.as_view(), name='topic'),
  6.     path('topic/add/', TopicCreate.as_view(), name='topic-add'),
  7.     path('topic/<int:pk>/', TopicUpdate.as_view(), name='topic-update'),
  8.     path('topic/<int:pk>/delete/', TopicDelete.as_view(), name='topic-delete'),
  9.  
  10.     path('entry/add/', EntryCreate.as_view(), name='entry-add'),
  11. ]

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

  1. <!-- topics.html 中的调用代码 -->
  2.  
  3.  <a href="{% url 'mysite:topic-add' %}">添加主题</a>{% if topics %}
  4.         {% for topic in topics %}          <li><a href="{% url 'mysite:topic' topic.id %}" >{{ topic.text }}</a> </li>
  5.               <a href="{% url 'mysite:topic-update' topic.id %}">修改</a>
  6.             <a href="{% url 'mysite:topic-delete' topic.id %}">删除</a>{% endfor %}
  7.         {% else %}<p>还没有任何主题</p>{% endif %}<!-- topic.html 中的调用代码 -->
  8.  
  9. <a href="{% url 'mysite:entry-add' %}">添加内容</a>
  10.     <h1>{{ topic }}</h1>
  11. <!-- 请仔细体会我们这里用的 topic.entry_set.all 方法 -->{% for entry in topic.entry_set.all %}
  12.         {{ entry.text }}       <p>日期:{{ entry.date_added }}</p>{% endfor %}

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

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

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号