老男孩IT教育,只培养技术精英

全国免费咨询电话:400-609-2893
Django如何搞定Views组件?

    /    2018-12-11

单纯返回字符串

def current_datetime(request):
    now = datetime.datetime.now()
    html = "It is now %s." % now
    return HttpResponse(html)
    #return HttpResponseNotFound('Page not found')
 
    # Return a "created" (201) response code.
    #return HttpResponse(status=201)

返回html文件

def detail(request, poll_id):
    try:
        p = Poll.objects.get(pk=poll_id)
    except Poll.DoesNotExist:
        raise Http404("Poll does not exist")
    return render(request, 'polls/detail.html', {'poll': p})

加装饰器

@login_required
def user_list(request):
     
    users = models.Account.objects.all()
     
    return render(request,'account.html',{'account_list':users})

只允许特定方法

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

CBV(Class based views)

Python是一个面向对象的编程语言,如果只用函数来开发,有很多面向对象的优点就错失了(继承、封装、多态)。所以Django在后来加入了CBV(Class-Based-View)。CBV就是在视图里使用类处理请求。

即可以让我们用类写View。这样做的优点主要下面两种:

1)提高了代码的复用性,可以使用面向对象的技术,比如Mixin(多继承);

2)可以用不同的函数针对不同的HTTP方法处理,而不是通过很多if判断,提高代码可读性。

from django.http import HttpResponse
from django.views import View
 
class MyView(View):
    def get(self, request):
        #         return HttpResponse('result')

Django的url收到请求后,是需要把这个请求分配给一个可调用的函数的,而不是一个class。针对这个问题,class-based view提供了一个as_view()静态方法(也就是类方法),调用这个方法,会创建一个类的实例,然后通过实例调用dispatch()方法,dispatch()方法会根据request的method的不同调用相应的方法来处理request(如get() , post()等)。到这里,这些方法和function-based view差不多了,要接收request,得到一个response返回。如果方法没有定义,会抛出HttpResponseNotAllowed异常。

在url中,就这么写:

# urls.py
from django.urls import path
from myapp.views import MyView
 
urlpatterns = [
    path('about/', MyView.as_view()),
]

cbv视图属性设置

类的属性可以通过两种方法设置,第一种是常见的Python的方法,可以被子类覆盖。

from django.http import HttpResponse
from django.views import View
 
class GreetingView(View):
    greeting = "Good Day"
 
    def get(self, request):
        return HttpResponse(self.greeting)

子类中只需继承

class MorningGreetingView(GreetingView):
    greeting = "Morning to ya"

第二种方法,你也可以在url中指定类的属性:

在url中设置类的属性Python

urlpatterns = [
    path('about/', GreetingView.as_view(greeting="G'day")),
]

(6)

分享至