https://docs.djangoproject.com/en/3.2/ref/class-based-views/
| 순서 | 메소드 | 설명 |
|---|---|---|
| 1 | setup(request, *args, **kwargs) | dispatch()에 앞서 키 초기화를 수행. 이 메소드를 덮어쓰면, super()를 호출해야 한다. |
| 2 | dispatch(request, *args, **kwargs) | view보기 의 일부 - request 인수와 인수 를 받아들이고 HTTP response을 반환하는 메서드입니다 . 기본 구현은 HTTP 메서드를 검사하고 HTTP 메서드와 일치하는 메서드에 위임을 시도합니다; GET은 get()에, POST는 post()에, 등등. 기본적으로 HEAD요청은 get()에 위임됩니다. HEAD와 다른 방식으로 요청 을 처리해야 하는 경우, head()메서드를 GET재정의할 수 있습니다. |
| 3 | http_method_not_allowed(request, *args, **kwargs) | 뷰가 지원하지 않는 HTTP 메서드로 호출된 경우 이 메서드가 대신 호출됩니다. 기본 구현은 HttpResponseNotAllowed일반 텍스트로 된 허용된 메서드 목록과 함께 반환 됩니다. |
| 4 | options(request, *args, **kwargs) | OPTIONS HTTP 동사에 대한 요청에 대한 응답을 처리합니다. 보기에 허용된 HTTP 메서드 이름 목록이 포함된 Allow헤더가 있는 응답을 반환 합니다. |
Method Flowchart
from django.views.generic.base import TemplateView from articles.models import Article class HomePageView(TemplateView): template_name = "home.html" def get_context_data(self, **kwargs): context = super().get_context_data(**kwargs) context['latest_articles'] = Article.objects.all()[:5] return context
적절한 경우 alters_data 를 사용하십시오.
템플릿 컨텍스트에 뷰 인스턴스가 있으면 잠재적으로 위험한 방법을 템플릿 작성자에게 노출시킬 수 있습니다. 이와 같은 메소드가 템플리트에서 호출되지 않도록하려면 해당 메소드에서 alters_data=True 를 설정 하십시오. 자세한 내용 은 템플릿 컨텍스트 렌더링에 대한 설명서를 참조하십시오.
Method Flowchart