Django基于类的增删改查,简单逻辑都不用写
2019-01-08 08:24:15来源:博客园 阅读 ()
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的相关知识,有兴趣的朋友可以关注本人微信公众号:幸福关中
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Python 猜数字游戏
下一篇:Python 高阶函数
- Django项目中使用qq第三方登录。 2019-08-13
- Django和前端用ajax传输json等数据 2019-08-13
- Django基本知识 2019-08-13
- JavaScript获取Django模板中指定键值的数据,使用过滤器 2019-08-13
- django框架使用及创建项目 2019-07-24
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash