美文网首页
Views#1-基础

Views#1-基础

作者: wangfp | 来源:发表于2017-09-19 13:34 被阅读0次

    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<year>[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<year>[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-基础

          本文链接:https://www.haomeiwen.com/subject/kpdwsxtx.html