Django for Beginners: A Complete Guide to Building Your First Web App

Django is one of the most popular frameworks for building web applications in Python. If you're a beginner interested in creating your first web app, Django offers a powerful and easy-to-use framework that will get you up and running in no time. In this comprehensive guide, we’ll take you through everything you need to know to build your first Django web app from scratch.

Whether you’re new to Django, Python, or web development in general, this tutorial will guide you through the basics while highlighting essential tools and techniques. We'll also cover key concepts like Django ORM, Django admin, Django REST framework (DRF), and integration with Docker, PostgreSQL, and more.

What is Django?

Django is a high-level Python web framework that encourages rapid development and clean, pragmatic design. It was created to make web development more manageable and scalable, allowing developers to focus on writing their apps rather than reinventing the wheel. With Django, you get several built-in features, like user authentication, admin panels, and an ORM (Object-Relational Mapping) system, making it easier to create complex web applications.

Why Use Django?

Here are some of the reasons Django is a great choice for beginners:

  • Fast development: Django handles much of the backend tasks, so you can focus on writing your application.
  • Scalability: Django scales well as your project grows.
  • Secure: Built-in security features help protect your app from common threats.
  • Versatile: It can be used for all types of web applications, including APIs and full-stack websites.

Setting Up Your Django Project

Before building your web app, you’ll need to set up your development environment. Follow these steps to get started:

Create a new directory for your project. This is where your project will be. Open command line

mkdir django-project

cd django-project

Create virtual environment python

Once you’re inside the django-project/ directory, it’s a good idea to create a virtual environment to manage dependencies. The following command is use to create a virtual environment all operating system i.e Windows, Linux + macOS

python -m venv venv

This command will create a venv folder in your working directory. Inside this directory, you’ll find several files, including a copy of the Python standard library. Later, when you install new dependencies, they’ll also live in this directory. Next, you need to activate the virtual environment by running the following command:

Activate virtual environment

  1. Windows: venv\Scripts\activate
  2. Linux + macOS: source venv/bin/activate

With the above commands, you create and activate a virtual environment named venv by using Python’s built-in venv module. The parenthetical (venv) in front of the prompt indicates that you’ve successfully activated the virtual environment.

virtual environment
created and activated a virtual environment

Now that you’ve created and activated a virtual environment, it’s time to install Django. You can do this using pip:

1. Install Django

Django is built in Python, so you'll first need to install Python. If you haven’t installed Python yet, download it from the official Python website. After installing Python, you can install Django via pip:

pip install django

2. How To Create Django Project

Once Django is installed, create a new Django project by running the following command with a fullstop at the end to avoid duplicating  project folder:

django-admin startproject myfirstproject .

This will create a new folder with your project files. Your file structure should look like this:

Your file structure should look like this

3. Run the Development Server

To see your new project in action, run the development server:

python manage.py runserver

Now, open your web browser and go to http://127.0.0.1:8000/. You should see the Django welcome page!

The install worked successfully!

Building Your First Django Web App

Now that your project is set up, let’s build a simple blog application to introduce you to the core concepts of Django.

1. Create a New App

In Django, a project can contain multiple apps. Let’s create our first app, “blog”:

python manage.py startapp blog

2. Define Your Models

Django models define the structure of your database. Let’s create a Post model for our blog:

blog/models.py

from django.db import models class Post(models.Model): title = models.CharField(max_length=200) content = models.TextField() created_at = models.DateTimeField(auto_now_add=True)

3. Create and Run Migrations

After defining your models, you need to create migrations and apply them to the database:

python manage.py makemigrations
python manage.py migrate

4. Register Models in the Admin Interface

Django provides a powerful admin interface. To manage your posts via the admin panel, register the Post model:

blog/admin.py

from django.contrib import admin from .models import Post admin.site.register(Post)

Now, create a superuser to access the admin panel:

python manage.py createsuperuser

After creating your superuser, log into the admin panel by visiting http://127.0.0.1:8000/admin/.

5. Create Views and Templates

Let’s create a view to display our blog posts:

blog/views.py

from django.shortcuts import render from .models import Post def blog_home(request): posts = Post.objects.all() return render(request, 'blog/home.html', {'posts': posts})

Next, create a simple HTML template to display the posts:

inside your blog, create a templates folder. inside the template folder create a folder the name blog. inside the blog folder, create home.html

<!-- blog/templates/blog/home.html -->

<!DOCTYPE html> <html> <head> <title>My Blog</title> </head> <body> <h1>Blog Posts</h1> {% for post in posts %} <h2>{{ post.title }}</h2> <p>{{ post.content }}</p> <hr> {% endfor %} </body> </html>

6. Set Up URL Routing

Now, map your view to a URL. Add the following code to blog/urls.py:

blog/urls.py

from django.urls import path from . import views urlpatterns = [ path('', views.blog_home, name='blog-home'), ]

And include this in your project’s main urls.py file:

# myfirstproject/urls.py

from django.contrib import admin from django.urls import path, include urlpatterns = [ path('admin/', admin.site.urls), path('', include('blog.urls')), ]

You should now be able to visit http://127.0.0.1:8000/ and see your blog posts displayed.

Django REST Framework: Creating an API

If you plan to build APIs, Django REST Framework (DRF) is an essential tool. It simplifies building RESTful APIs using Django. To install DRF:

pip install djangorestframework

Add 'rest_framework' to your INSTALLED_APPS in settings.py:

INSTALLED_APPS = [
'rest_framework', # other apps ]

Here’s a simple example of how to create an API for your Post model:

# blog/serializers.py

from rest_framework import serializers from .models import Post class PostSerializer(serializers.ModelSerializer): class Meta: model = Post fields = '__all__'

# blog/views.py

from rest_framework.response import Response from rest_framework.decorators import api_view from .models import Post from .serializers import PostSerializer @api_view(['GET']) def api_post_list(request): posts = Post.objects.all() serializer = PostSerializer(posts, many=True) return Response(serializer.data)

Finally, update your urls.py to include the API route:

# blog/urls.py

from django.urls import path from . import views urlpatterns = [ path('', views.blog_home, name='blog-home'), path('api/posts/', views.api_post_list, name='api-post-list'), ]

Conclusion

Congratulations! You’ve built your first Django web app from scratch. From creating a basic blog to understanding Django REST framework, this complete guide introduced you to key features like Django ORM, models, admin interface, and API development.

Django for beginners can be a smooth ride if you follow the right steps, and this tutorial aimed to make your journey as beginner-friendly as possible.

Frequently Asked Queries:

  • What is Django? Django is a high-level Python framework used for rapid web development.
  • How do I create a superuser in Django? Use the python manage.py createsuperuser command.
  • What is Django REST framework? It's a toolkit for building Web APIs in Django.