====== Built-in class-based views API ====== https://docs.djangoproject.com/en/3.2/ref/class-based-views/ * Base views * View * TemplateView * RedirectView * Generic display views * DetailView * ListView * Generic editing views * FormView * CreateView * UpdateView * DeleteView * Generic date views * ArchiveIndexView * YearArchiveView * MonthArchiveView * WeekArchiveView * DayArchiveView * TodayArchiveView * DateDetailView * Class-based views mixins * Simple mixins * ContextMixin * TemplateResponseMixin * Single object mixins * SingleObjectMixin * SingleObjectTemplateResponseMixin * Multiple object mixins * MultipleObjectMixin * MultipleObjectTemplateResponseMixin * Editing mixins * FormMixin * ModelFormMixin * ProcessFormMixin * DeletionMixin * Date-based mixins * YearMixin * MonthMixin * DayMixin * WeekMixin * DateMixin * BaseDeteListMixin * Class-based generic views - flattened index * Simple generic views * View * Template View * Redirect View * Detail Views * DetailView * List Views * ListView * Editing views * FormView * CreateView * UpdateView * DeleteView * Date-based views * ArchiveIndexView * YearArchiveView * MonthArchiveView * WeekArchiveView * DayArchiveView * TodayArchiveView * DateDetailView ===== class-based의 메소드 호출 ===== ==== View ==== ^ 순서 ^ 메소드 ^ 설명 ^ | 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**헤더가 있는 응답을 반환 합니다. | ==== TemplateView ==== **Method Flowchart** - setup() - dispatch() - http_method_not_allowed() - get_context_data() * get_context_data(%%**%%kwargs) - 템플릿 컨텍스트를 나타내는 사전을 반환합니다. 제공된 키워드 인수는 반환된 컨텍스트를 구성합니다. 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 를 설정 하십시오. 자세한 내용 은 템플릿 컨텍스트 렌더링에 대한 설명서를 참조하십시오. ==== RedirectView ==== **Method Flowchart** - setup() - dispatch() - http_method_not_allowed() - get_redirect_url() * get_redirect_url(*args, %%**%%kwargs) - 리디렉션 할 대상 URL을 구성합니다.