/ 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")), ]
(12)