Home Backend Development Python Tutorial Django study notes - Class-Based-View

Django study notes - Class-Based-View

Feb 18, 2017 am 10:17 AM

Preface

Everyone knows that learning Django is actually very simple, and you can get started with almost no effort. There is almost nothing difficult to understand about configuring a URL, assigning it to a function to process it, and returning a response.

After writing too much, some problems are gradually realized. For example, one view is relatively complex and calls many other functions. What should I do if I want to encapsulate these functions? Of course, you can use the comment #------view------ to isolate the function. This method is too low. It is simply deceiving yourself. It is not even encapsulated.

Python is an object-oriented programming language. If you only use functions for development, many object-oriented advantages will be missed (inheritance, encapsulation, polymorphism). So Django later added Class-Based-View. It allows us to write View using classes. The advantages of doing this are mainly the following two:

  1. Improves the reusability of code, and you can use object-oriented technology, such as Mixin (multiple inheritance)

  2. You can use different functions to handle different HTTP methods instead of judging by many ifs to improve code readability

##Use class-based views

#If we want to write a view that handles the GET method, it would be as follows when written using a function.

from django.http import HttpResponse
 
def my_view(request):
 if request.method == 'GET':
  # <view logic>
  return HttpResponse(&#39;result&#39;)
Copy after login

If written in class-based view, it would be as follows.

from django.http import HttpResponse
from django.views import View
 
class MyView(View):
 def get(self, request):
  # <view logic>
  return HttpResponse(&#39;result&#39;)
Copy after login

Django's url assigns a request to a callable function, not a class. To solve this problem, class-based view provides a

as_view()static method (that is, class method). Calling this method will create an instance of the class, and then call dispatch() through the instance. method, dispatch() method will call the corresponding method to process the request according to the different method of the request (such as get() , post() wait). At this point, these methods are almost the same as function-based views. They need to receive requests and get a response back. If the method is not defined, an HttpResponseNotAllowed exception will be thrown.

In the url, just write:

# urls.py
from django.conf.urls import url
from myapp.views import MyView
 
urlpatterns = [
 url(r&#39;^about/$&#39;, MyView.as_view()),
]
Copy after login

The attributes of the class can be set in two ways, the first is the common Python Methods can be overridden by subclasses.

from django.http import HttpResponse
from django.views import View
 
class GreetingView(View):
 greeting = "Good Day"
 
 def get(self, request):
  return HttpResponse(self.greeting)
 
# You can override that in a subclass
 
class MorningGreetingView(GreetingView):
 greeting = "Morning to ya"
Copy after login

The second method, you can also specify the attributes of the class in the url:

Set the attributes of the class in the url Python

urlpatterns = [
 url(r&#39;^about/$&#39;, GreetingView.as_view(greeting="G&#39;day")),
]
Copy after login

Using Mixin

I think we need to understand django’s class-based -view (hereinafter referred to as cbv), first of all, you must understand the purpose of introducing cbv to django. Before Django 1.3, the generic view was the so-called universal view, which used function-based-view (fbv), which is a function-based view. Some people think that fbv is more pythonic than cbv, but they think otherwise. One of the important features of Python is object-oriented. And cbv can better reflect the object-oriented nature of Python. cbv implements view methods through classes. Compared with function, class can make better use of the specificity of polymorphism, so it is easier to abstract the more common functions within the project from a macro level. Regarding polymorphism, there is not much explanation. Interested students can Google it themselves. In short, it can be understood as one thing having multiple forms (characteristics). The implementation principle of cbv can be easily understood by looking at the source code of Django. Generally speaking, after the url is routed to this cbv, it is distributed through the dispatch method inside cbv, the get request is distributed to the cbv.get method for processing, and the post request is distributed to cbv. .post method processing, other methods are similar. How to use polymorphism? The concept of mixin is introduced in cbv. Mixin is just some basic classes that have been written, and then combined with different Mixins to become the final desired class.


So, the basis for understanding cbv is to understand Mixin. Mixins are used in Django to reuse code. A View Class can inherit multiple Mixins, but can only inherit one View (including subclasses of View). It is recommended to write View on the far right and multiple Mixins on the left. Mixin is also a relatively complex technology. I won’t go into details in this article. I will write an article about Mixin in the future.

Using decorators

In CBV, you can use method_decorator to decorate methods.

from django.contrib.auth.decorators import login_required
from django.utils.decorators import method_decorator
from django.views.generic import TemplateView
 
class ProtectedView(TemplateView):
 template_name = &#39;secret.html&#39;
 
 @method_decorator(login_required)
 def dispatch(self, *args, **kwargs):
  return super(ProtectedView, self).dispatch(*args, **kwargs)
Copy after login

can also be written on the class and pass in the name of the method.

@method_decorator(login_required, name=&#39;dispatch&#39;)
class ProtectedView(TemplateView):
 template_name = &#39;secret.html&#39;
Copy after login

If there are multiple decorators decorating a method, they can be written as a list. For example, the following two ways of writing are equivalent.

decorators = [never_cache, login_required]
 
@method_decorator(decorators, name='dispatch')
class ProtectedView(TemplateView):
 template_name = 'secret.html'
 
@method_decorator(never_cache, name='dispatch')
@method_decorator(login_required, name=&#39;dispatch&#39;)
class ProtectedView(TemplateView):
 template_name = &#39;secret.html&#39;
Copy after login


For more articles related to Class-Based-View of Django study notes, please pay attention to the PHP Chinese website!


Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to Use Python to Find the Zipf Distribution of a Text File How to Use Python to Find the Zipf Distribution of a Text File Mar 05, 2025 am 09:58 AM

This tutorial demonstrates how to use Python to process the statistical concept of Zipf's law and demonstrates the efficiency of Python's reading and sorting large text files when processing the law. You may be wondering what the term Zipf distribution means. To understand this term, we first need to define Zipf's law. Don't worry, I'll try to simplify the instructions. Zipf's Law Zipf's law simply means: in a large natural language corpus, the most frequently occurring words appear about twice as frequently as the second frequent words, three times as the third frequent words, four times as the fourth frequent words, and so on. Let's look at an example. If you look at the Brown corpus in American English, you will notice that the most frequent word is "th

How Do I Use Beautiful Soup to Parse HTML? How Do I Use Beautiful Soup to Parse HTML? Mar 10, 2025 pm 06:54 PM

This article explains how to use Beautiful Soup, a Python library, to parse HTML. It details common methods like find(), find_all(), select(), and get_text() for data extraction, handling of diverse HTML structures and errors, and alternatives (Sel

How to Download Files in Python How to Download Files in Python Mar 01, 2025 am 10:03 AM

Python provides a variety of ways to download files from the Internet, which can be downloaded over HTTP using the urllib package or the requests library. This tutorial will explain how to use these libraries to download files from URLs from Python. requests library requests is one of the most popular libraries in Python. It allows sending HTTP/1.1 requests without manually adding query strings to URLs or form encoding of POST data. The requests library can perform many functions, including: Add form data Add multi-part file Access Python response data Make a request head

Image Filtering in Python Image Filtering in Python Mar 03, 2025 am 09:44 AM

Dealing with noisy images is a common problem, especially with mobile phone or low-resolution camera photos. This tutorial explores image filtering techniques in Python using OpenCV to tackle this issue. Image Filtering: A Powerful Tool Image filter

How to Work With PDF Documents Using Python How to Work With PDF Documents Using Python Mar 02, 2025 am 09:54 AM

PDF files are popular for their cross-platform compatibility, with content and layout consistent across operating systems, reading devices and software. However, unlike Python processing plain text files, PDF files are binary files with more complex structures and contain elements such as fonts, colors, and images. Fortunately, it is not difficult to process PDF files with Python's external modules. This article will use the PyPDF2 module to demonstrate how to open a PDF file, print a page, and extract text. For the creation and editing of PDF files, please refer to another tutorial from me. Preparation The core lies in using external module PyPDF2. First, install it using pip: pip is P

How to Cache Using Redis in Django Applications How to Cache Using Redis in Django Applications Mar 02, 2025 am 10:10 AM

This tutorial demonstrates how to leverage Redis caching to boost the performance of Python applications, specifically within a Django framework. We'll cover Redis installation, Django configuration, and performance comparisons to highlight the bene

Introducing the Natural Language Toolkit (NLTK) Introducing the Natural Language Toolkit (NLTK) Mar 01, 2025 am 10:05 AM

Natural language processing (NLP) is the automatic or semi-automatic processing of human language. NLP is closely related to linguistics and has links to research in cognitive science, psychology, physiology, and mathematics. In the computer science

How to Perform Deep Learning with TensorFlow or PyTorch? How to Perform Deep Learning with TensorFlow or PyTorch? Mar 10, 2025 pm 06:52 PM

This article compares TensorFlow and PyTorch for deep learning. It details the steps involved: data preparation, model building, training, evaluation, and deployment. Key differences between the frameworks, particularly regarding computational grap

See all articles