Skip to main content

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.

Comments

Popular posts from this blog

Tips for Landing Tech Jobs and Acing Interviews

The tech industry is one of the fastest-growing and highest-paying fields today. Whether you’re a developer, data analyst, cybersecurity specialist, or UI/UX designer, there are plenty of opportunities. But with so many skilled candidates competing for the same roles, simply having technical knowledge isn’t enough. You need a strategy to stand out, showcase your skills, and navigate the hiring process with confidence. Breaking into tech or advancing your career requires more than just knowing how to code.  Companies look for professionals who can problem-solve, communicate effectively, and adapt to new technologies. To help you land that dream job and excel in interviews, here are practical steps you can take: Check out our  article on  How To Start Freelancing in Tech Building a strong technical foundation is essential. If you’re new to tech, start by mastering the fundamentals. For software engineering roles, focus on languages like Python, JavaScript, or Java. If yo...

How to Enable USB Debugging on Oculus Quest 2

  The Oculus Quest 2 is a powerful VR headset that offers endless possibilities, from gaming to app development. However, to unlock its full potential, you’ll need to enable   USB debugging   and   Developer Mode . Whether you’re a developer looking to sideload apps or a user troubleshooting your device, this guide will walk you through the process step by step. In this post, we’ll cover: How to enable USB debugging on Oculus Quest 2. How to activate Developer Mode. How to access Oculus debug tools. Troubleshooting tips for common issues. Let’s dive in! What is USB Debugging and Why Enable It? USB debugging is a feature that allows your Oculus Quest 2 to communicate with a computer via a USB connection. This is essential for: Sideloading apps : Installing apps from third-party sources like SideQuest. App development : Testing and debugging VR applications. Troubleshooting : Diagnosing and fixing device issues. Enabling USB debugging requires activating  Deve...

Frontend and Backend Integration with RESTful APIs in Python and Django

Frontend and Backend Integration with RESTful APIs in Python and Django Integrating frontend and backend systems is a very important skill for web developers. It enables seamless data flow and dynamic interactions on modern websites. This tutorial focuses on using RESTful APIs for frontend-backend integration in Python and Django , breaking down important steps to help beginners and intermediate developers create smooth, efficient communication between the frontend and backend. What is Frontend-Backend Integration? Frontend-backend integration involves creating a bridge between the part of a web application users see and interact with ( the frontend)  and the part that handles data processing, logic, and storage ( the backend).   The frontend sends data requests to the backend,...

Coding Programs for Kids

In today’s digital age, learning to code is becoming as fundamental as reading and writing. Coding programs for kids are designed to make programming fun, interactive, and accessible, helping children develop critical skills that are essential for the future workforce. This guide will take you through the ins and outs of coding programs for kids, the best platforms to get started, and how coding can benefit children of all ages. What is coding for kids? Coding for kids involves teaching programming concepts through simplified platforms and languages designed to be user-friendly for young learners. From creating simple games to building animations, kids as young as three years old can start engaging in coding activities. The growing availability of coding programs for kids makes it easier for parents and educators to provide children with the tools to learn this valuable skill. These platforms range from drag-and-drop interfaces that require no prior experience to more complex languages...

Understanding Object-oriented programming

Object-Oriented Programming (OOP) is one of the most widely used paradigms in modern programming. It revolves around the concept of organizing code into objects that represent real-world entities. By structuring code through classes, objects, inheritance, polymorphism, and encapsulation, OOP allows for more organized, reusable, and scalable software development. What is Object-Oriented Programming? Object-Oriented Programming (OOP) is a programming paradigm centered on the use of objects and classes . Unlike procedural programming, which relies on a step-by-step approach, OOP models software based on entities or objects that interact with each other. Objects are instances of classes, which act as blueprints defining attributes and behaviors. At its core, OOP seeks to create programs that are more modular, making it easier to manage and modify as requirements evolve. Re ad my tutori al blog  article on  A px Java Tutorial The Evolution of Programming Paradigms Before OOP, proc...

Hacktoberfest 2024: What You Should Know and What You Should Do

As the leaves begin to turn and the air grows crisp, the developer community gears up for one of the most anticipated events of the year: Hacktoberfest . Whether you're a seasoned open-source contributor or someone new to coding, Hacktoberfest is an excellent opportunity to sharpen your skills, contribute to meaningful projects, and connect with a global community of developers. With just over a month to go before Hacktoberfest 2024 kicks off, now is the perfect time to get prepared. In this post, we'll dive into everything you need to know about Hacktoberfest and offer actionable steps on how to make the most out of the event. What is Hacktoberfest? Hacktoberfest, initiated by DigitalOcean in 2014, is an annual event that encourages developers around the world to contribute to open-source projects. It takes place every October, with the primary goal of promoting open-source contributions and giving back to the developer community. Participants are challenged to submit a minimu...

Front End Web Developer Average Salary

 Embarking on a career as a front-end web developer is an exciting journey, blending creativity with technical prowess. One of the pivotal questions aspiring developers often ponder is: What is the average salary for a front-end web developer? Let's delve into this topic, addressing common concerns and providing a comprehensive overview. For more insights on advancing your career as a front-end developer, check out our comprehensive guide on  how to land a front-end web developer job . Understanding the Role of a Front-End Web Developer A front-end web developer is responsible for designing and implementing the visual and interactive aspects of a website—the parts users directly engage with. This includes: Layout and Design : Crafting the structure and appearance of web pages. User Interface (UI) Elements : developing buttons, menus, and other interactive components. Responsive Design : Ensuring websites function seamlessly across various devices and screen sizes. Proficiency...

Visual Web Developer

Embarking on the journey to become a visual web developer is both exciting and rewarding. Whether you're just starting out or looking to enhance your existing skills, understanding the nuances of this role can set you on the path to success. In this comprehensive guide, we'll address common questions, share personal insights, and provide practical advice to help you thrive in the world of visual web development. What is a Visual Web Developer? A visual web developer focuses on creating the visual aspects of websites, ensuring they are both aesthetically pleasing and user-friendly. This role combines design principles with coding skills to build interactive and responsive web pages. Unlike traditional web developers, who may focus solely on functionality, visual web developers prioritize the look and feel of a site, working closely with designers and UX professionals to bring concepts to life. Common Questions and Concerns 1. Do I Need a Design Background to Become a Visual Web...

AWS SQS Tutorial for Java Developers

If you're a Java developer looking to build scalable, decoupled applications, Amazon Web Services (AWS) Simple Queue Service (SQS) is a tool you’ll want to master. But let’s be honest—getting started with AWS SQS can feel overwhelming, especially if you're new to cloud services or messaging systems. You might be wondering: How does SQS work, and why should I use it? What’s the best way to integrate SQS with my Java application? Are there any common pitfalls I should avoid? Don’t worry—I’ve been there too. When I first started working with SQS, I spent hours sifting through documentation and experimenting with code. That’s why I’ve put together this AWS SQS tutorial for Java developers. By the end of this guide, you’ll have a solid understanding of how to use SQS in your Java projects, along with practical examples and tips to make your life easier. If you’re new to Java or want to sharpen your skills, check out this: The Best Online Java Courses for Beginners What is AWS SQS, a...