管理器Manage+元选项+路由详解

管理器Manage

管理器是Django的模型进行数据库操作的接口,Django应用的每个模型类都拥有至少一个管理器

管理器对象objects,(默认)

作用:

  • 修改原始查询集
  • 向管理器类中添加额外的方法,

定义管理器对象类

booktest/models.py下


class BookInfoManager(models.Manager):
    # 重写all()方法
    def all(self):
        # 筛选出 isDelete = 0 的全部返回
        return super().all().filter(isDelete=False)
    def create_book(self, title, pub_date):
        # 调用此方法直接将对象保存到数据库
        book = self.model()
        book.btitle =title
        book.bpub_date=pub_date
        book.bread = 0
        book.bcomment = 0
        book.isDelete = False
        book.save()
        return book

为模型类BookInfo定义管理器books

class BookInfo(models.Model):
    books = BookInfoManager()

调用

from datetime import date
book=BookInfo.books.create_book("射雕英雄传",date(1980,1,1))

元选项

数据表名称

<app_name>_<model_name>
例:
booktest_bookinfo

例:指定BookInfo模型类生成的数据表名为bookinfo。

#定义图书模型类BookInfo
class BookInfo(models.Model):
    #定义元选项
    class Meta:
        db_table = 'bookinfo' # 指定模型类对应表名

URL

用户通过在浏览器的地址栏中输入网址请求网站,对于Django开发的网站,由哪一个视图进行处理请求,是由url匹配找到的。

配置

settings.py中通过ROOT_URLCONF指定url配置,默认已经有此配置。



urls.py可以看到默认配置。


  • urls.py中进行包含配置,在各自应用中创建具体配置。
  • 定义urlpatterns列表,存储url()对象,这个名称是固定的。
  • urlpatterns中的每个正则表达式在第一次访问它们时被编译,这使得运行很快。

语法

url()对象,被定义在django.conf.urls包中,有两种语法结构

语法一

一般在自定义应用中创建一个urls.py来定义url。

url(正则,include('应用.urls'))
语法二

指定URL和视图函数的对应关系。
在应用内部创建urls.py文件,指定请求地址与视图的对应关系

url(正则,'视图函数名称')
  • view视图的处理必须返回HttpResponse对象或者子类对象
from django.shortcuts import render
from booktest.models import *
def index(request):
    books=BookInfo.objects.all()
    return render(request,'booktest/index.html',{'books':books})
  • 正则部分推荐使用r,表示字符串不转义,这样在正则表达式中使用\只写一个就可以。
  • 不能在开始加反斜杠,推荐在结束加反斜杠。

在视图中添加位置参数

booktest/urls.py文件,定义与这个地址匹配的url

url(r'^delete\d+/$',views.show_arg),

booktest/views.py中创建视图show_arg。

def show_arg(request):
    return HttpResponse('show_arg')

启动服务端

  • 位置参数
    直接使用小括号,通过位置参数传递给视图。
url(r'^delete(\d+)/$',views.show_arg),

视图show_arg

def show_arg(request,id):
    return HttpResponse('show arg {}'.format(id))
  • 关键字参数
    在正则表达式部分为组命名
    ?P部分表示为这个参数定义的名称为id
url(r'^delete(?P<id1>\d+)/$',views.show_arg),

视图show_arg此时必须要有一个参数名为id1

def show_arg(request,id1):
    return HttpResponse('show{}'.format(id1))

调试信息


当DEBUG=False,
ALLOWED_HOSTS = ['*']时
关闭

404错误页面

在templates新建立404.html


500错误页面

500错误,调用内置错误视图,使用templates/500.html模板渲染。
如果在settings中DEBUG设置为True,那么将永远不会调用505视图,而是显示URLconf 并带有一些调试信息

HttpReqeust对象

属性

  • path:一个字符串,表示请求的页面的完整路径,不包含域名和参数部分。

  • method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET'、'POST'。

    • 在浏览器中给出地址发出请求采用get方式,如超链接。
    • 在浏览器中点击表单的提交按钮发起请求,如果表单的method设置为post则为post请求。
  • encoding:一个字符串,表示提交的数据的编码方式。

    • 如果为None则表示使用浏览器的默认设置,一般为utf-8。
    • 这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的encoding值。
  • GET:QueryDict类型对象,类似于字典,包含get请求方式的所有参数。

  • POST:QueryDict类型对象,类似于字典,包含post请求方式的所有参数。

  • FILES:一个类似于字典的对象,包含所有的上传文件。

  • COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串。

  • session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当Django 启用会话的支持时才可用,详细内容见"状态保持"。

GET属性

  • 分析请求参数,键为'a'、'b'、'c',值为'10'、'20'、'python'。
  • 在Django中可以使用HttpRequest对象的GET属性获得get方方式请求的参数。
  • GET属性是一个QueryDict类型的对象,键和值都是字符串类型。
  • 键是开发人员在编写代码时确定下来的。
  • 值是根据数据生成的。

POST属性

使用form表单请求时,method方式为post则会发起post方式的请求,需要使用HttpRequest对象的POST属性接收参数,POST属性是一个QueryDict类型的对象。
问:表单form如何提交参数呢?
答:表单控件name属性的值作为键,value属性的值为值,构成键值对提交。

  • 如果表单控件没有name属性则不提交。
  • 对于checkbox控件,name属性的值相同为一组,被选中的项会被提交,出现一键多值的情况。
  • 键是表单控件name属性的值,是由开发人员编写的。
  • 值是用户填写或选择的。
模拟
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<ul>
    <a href="/method_show_get/">点击get提交</a>
    <form  method="post" action="/method_show/">
        <input type="submit" value="post方式提交">
    </form>
    <h1>提交数据的两种方式</h1>
    <p>get方式</p>
    <a href="/get_submit/?a=10&b=20&c=python">点击get提交</a>
    <p>post方式</p>
    <form method="post" action="/post_submit/">
        姓名: <input type="text" name="uname"><br>
        性别: 男 <input type="radio" name="gender" value="男">
        女 <input type="radio" name="gender" value="女"><br>
        爱好:
       吃饭 <input type="checkbox" name="hobby" value="吃饭">
       睡觉 <input type="checkbox" name="hobby" value="睡觉">
        打豆豆<input type="checkbox" name="hobby" value="打豆豆">
        <br>
        <input type="submit" value="注册">
    </form>
</ul>
</body>
</html>
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容