Views#1-基础

URLconf

  • url()
    1. url()正则表达式中的参数既可以是位置参数,也可以是关键字参数
    # 位置参数,/article/2020对应的view函数为year_archive(request, '2020')
    url(r'^article/([0-9]{4}/$', views.year_archive, name='year_archive')
    
    # 关键字参数,/article/2020对应的view函数为year_archive(request, year='2020')
    url(r'^article/(?P[0-9]{4})/$', views.year_archive, name='year_archive')
    
    # 当然,`views.year_archive`函数定义时的API为`year_archive(request, year)`即可,因为其既可以接受位置参数,也可以接受关键字参数
    
    1. 模板中url标签
    # 传入位置参数
    {% url 'year_archive' 2020 %}
    
    # 传入关键字参数
    {% url 'year_archive' year=2020 %}
    
    1. url()中其它参数
    url(r'blog/(?P[0-9]{4})/$, views.year_archive, {'foo': 'bar'})
    # /blog/2020/将会调用year_archive(request, year='2020', foo='bar')
    
    # 注意:若url()函数中含有include(),那么字典中的参数将会应用到每个包含的url的views中
    
  • reverse()
    API:
    reverse(viewname, urlconf=None, args=None, kwargs=None, current_app=None)
    # args是位置参数,kwargs是关键字参数
    

Views

  • Http404
    可以自己实现引发Http404异常,并定义异常页面:
    templates/的直接目录下创建404.html文件,当DEBUG设置为False时,该模板将会被Http404异常使用
  • 重载'错误'视图函数
    必须在URLconf中进行重载:
    # 在mysite.views中定义重载视图函数
    handler404 = 'mysite.views.my_custom_page_not_found_view'
    # 如不重载,则默认为是django.views.defaults.page_not_found
    # 需要返回HttpResponseNotFound
    
    handler500 = 'mysite.views.my_custom_error_view'
    # 如不重载,则默认为是django.views.defaults.server_error
    # 需要返回HttpResponseServerError
    
    handler403 = 'mysite.views.my_custom_permission_denied_view'
    # 如不重载,则默认为是django.views.defaults.permission_denied
    # 需要返回HttpResponseForbidden
    
    handler400 = 'mysite.views.my_custom_bad_request_view'
    # 如不重载,则默认为是django.views.defaults.bad_request
    # 需要返回HttpResponseBadRequest
    

快捷函数(django.shortcuts)

  • render(request, template_name, context=None, content_type=None, status=None, user=None)
    • content_type:默认为text/html(在DEFAULT_CONTENT_TYPE中设置)
    • status:默认为200
    • using:加载模板使用的引擎名称
  • redirect(to, permanent=False, *args, **kwargs)
    返回HttpResponseRedirect
    参数to可以是
    • 一个model对象(自动调用该数据模型对象的get_absolute_url()函数)
    • 一个视图函数名称(可以使用reverse()函数)
    • 一个绝对URL路劲
  • get_object_or_404(klass, *args, *kwargs)
    • klass:Model类/Manager/QuerySet实例
    • **kwargs:查询参数,将会被用于get()方法
    from django.shortcuts import get_object_or_404
    
    def my_view(request):
        my_obj = get_object_or_404(MyModel, pk=1)
    
    等价于
    from django.http import Http404
    
    def my_view(request):
        try:
            my_obj = MyModel.objects.get(pk=1)
        else:
            raise Http404("No MyModel matches the given query.")
    
  • get_list_or_404(klass, *args, **kwargs)
    通过filter()进行查询

视图中的装饰器(django.views.decorators.http)

  • 限制HTTP请求方法
    限制视图函数可用的请求方法(若不符合要求,则返回django.http.HttpResponseNotAllowed
    • require_http_methods(reuqest_method_list)
      设置允许多个请求方法
      from django.views.decorators.http import require_http_methods
      
      # 方法使用大写表示
      @require_http_methods(["GET", "POST"])
      def my_view(request):
          # I can assume now that only GET or POST requests make it this far
          # ...
          pass
      
    • require_GET():只允许get方法
    • require_POST():只允许post方法
    • require_safe():允许get和head方法

request和response

Django通过requestresponse对象在系统中传递状态
当页面被创建,Django创建HttpRequest对象来保存元数据(视图函数中的第一个参数);每个视图函数则返回一个HttpResponse对象
HttpRequest和HttpResponse对象在django.http模块中定义

你可能感兴趣的:(Views#1-基础)