2016-06-15 3 views
0

Я изучаю классные представления в Django и научился работать с базовыми общими представлениями, такими как View и TemplateView.Установить пользовательский класс заголовка класса Django

Я играл с общим представлением, таким как ListView и DetailView, затем я наткнулся на проблему. Как добавить пользовательский заголовок в представлении класса, который наследуется от одного из классов представления, например ListView и DetailView.

Я искал его, но все ответы на функциональные представления.

Мне удалось установить заголовки в классах Base Views, которые наследуются от класса View.

class MyView(View): 
    http_method_names=['post','get'] 
    message='<div id="myview">This is a class based view response.</div>' 
    content_type='text/html' 
    charset='utf-8' 
    template_name='base.html' 

    @method_decorator(gzip_page) 
    @method_decorator(condition(etag_func=None,last_modified_func=None)) 
    def get(self,request,*args,**kwargs): 
     response=TemplateResponse(request,self.template_name,{'number':1,'number_2':2}) 
     response.__setitem__('x-uuid',uuid.uuid4().hex)  #set header explicitly 
     response.__setitem__('status',200) 
     response.__setitem__('page_id',str(uuid.uuid4().hex)) 
     patch_vary_headers(response,['Etag','Cookie','User-Agent']) 
     patch_cache_control(response) 
     return response 

    #Override this method to tell what to do when one of the methods in http_method_names is called 
    def http_method_not_allowed(request, *args, **kwargs): 
     response=HttpResponse("Method not allowed",status=405) 
     response.__setitem__('x-uid',uuid.uuid4().hex)  #set header explicitly 
     response.__setitem__('status',405) 
     response.__setitem__({'hello':'word'}) 
     return response 
     #return any type of response here 
    # return JsonResponse(status=405,data={'not_allowed':True}) 

Может кто-нибудь сказать мне, как добавить пользовательский заголовок в Class View Based, который наследуется от ListView или любого другого вида, подобного DetailView.

class GetParticularUserView(ListView): 
    http_method_names=['get'] 
    template_name='one_user.html' 
    # context_object_name='user'  # set context either by this or by get_context_data 
    '''queryset=User.objects.all()''' # one way to set the data in the context 

    def get_queryset(self): 
     # define the query set to be used here. 
     self.user=get_object_or_404(User,id=self.kwargs['id']) 
     return self.user 

    def get_context_data(self,**kwargs): 
     context=super(GetParticularUserView,self).get_context_data(**kwargs) 
     context['user']=self.user 
     return context 

ответ

0

Я бы отказался от метода dispatch. Вызовите super(), чтобы получить ответ, установите заголовки, затем верните ответ. Обратите внимание, что вам не нужно звонить __setitem__ - просто обработайте ответ как словарь.

class GetParticularUserView(ListView): 

    @method_decorator(gzip_page) 
    @method_decorator(condition(etag_func=None,last_modified_func=None)) 
    def dispatch(self, *args, **kwargs): 
     response = super(GetParticularUserView, self).dispatch(*args, **kwargs) 
     response['x-uid'] = uuid.uuid4().hex # set header 
     return response