Geek Slack

Start creating your course and become a part of GeekSlack.

Course Content
Django – Fundamentals
This chapter introduces the core concepts of Django applications, views, routing, and templates, forming the foundation for building dynamic web applications.
0/5
Django – Models and Databases
This chapter explores Django's Object-Relational Mapping (ORM), a powerful feature that allows you to interact with databases using Python objects instead of raw SQL. You'll learn how to define models, perform database migrations, and work with data efficiently.
0/7
Django – Forms and User Input
This chapter focuses on how to handle user input in Django applications using forms. You will learn how to create forms, validate data, process and render forms, and use models to create forms automatically. Additionally, you will explore handling file uploads, including saving and managing media files.
0/9
Django – Admin
The Django Admin panel is one of the most powerful features of Django, allowing developers and site administrators to manage content and data seamlessly through a web interface. This chapter explores advanced features of Django Admin, focusing on customization, registration of models, customizing the display and filtering, adding actions, and creating custom admin templates.
0/7
Django – Advanced Views and URL Handling
This chapter explores advanced techniques for handling views, URLs, and middleware in Django. You'll gain a deep understanding of Class-Based Views (CBVs) and how they compare to Function-Based Views (FBVs), learn about organizing URLs effectively for large projects, and dive into middleware: a key component for processing requests and responses globally.
0/6
Django – User Authentication and Authorization
User authentication and authorization are crucial aspects of modern web applications. Django provides a comprehensive, built-in system for handling user authentication, allowing developers to easily manage user registration, login, password management, and access control. This chapter covers advanced techniques in managing users, roles, permissions, and custom user models in Django.
0/7
Django – Static and Media Files
In Django, handling static and media files efficiently is an essential aspect of web development. Static files (e.g., JavaScript, CSS, images) are files that do not change during runtime, while media files (e.g., user-uploaded files like photos, documents) are dynamic and may change or be added over time. This chapter explores how to manage both static and media files in Django, including their configuration for development and production environments.
0/3
Django – Testing and Debugging
Testing and debugging are critical skills for building robust, reliable Django applications. This chapter covers strategies to debug Django applications effectively, common errors and their fixes, and writing comprehensive tests using Django's built-in testing framework.
0/6
Django – REST Framework (Optional Advanced Section)
Django REST Framework (DRF) is a powerful and flexible toolkit for building Web APIs with Django. This chapter introduces you to REST principles, guides you through setting up DRF, and explores advanced concepts like serializers, views, routers, and authentication mechanisms.
0/6
Django – Deployment
Deploying a Django application ensures that your project is accessible to users over the internet. This chapter covers the steps to prepare your application for deployment, tools and configurations for different deployment scenarios, and best practices for securing Django applications in a production environment.
0/6
Django Tutorial
About Lesson

Static files are assets like JavaScript files, CSS stylesheets, and images that are part of your application’s frontend but are not generated dynamically. Django makes it easy to serve static files in both development and production environments.

Configuring Static Files in Django

Django automatically handles static files during development, but you need to configure settings for both the development and production environments.

Basic Configuration:

In settings.py, Django provides the STATIC_URL setting to define the URL where static files are served. By default, Django uses a directory named static/ to store all static files in your project.

# settings.py

# URL to access static files
STATIC_URL = '/static/'

# Directory to store static files during development
STATICFILES_DIRS = [
    BASE_DIR / "static",  # For custom static directories
]

# The directory where collectstatic will store static files for production
STATIC_ROOT = BASE_DIR / "staticfiles"
  • STATIC_URL: This is the URL to access the static files (e.g., /static/).
  • STATICFILES_DIRS: This is a list of directories where Django will look for additional static files during development.
  • STATIC_ROOT: This is the absolute path to the directory where all static files will be collected when you run collectstatic for production. It is empty by default.

Example of Static File in Django Template:


  {% load static %}
  <link rel="stylesheet" type="text/css" href="{% static 'css/styles.css' %}">
  <script src="{% static 'js/app.js' %}"></script>
  

 

Serving Static Files in Development

When you’re running the Django development server (python manage.py runserver), Django automatically serves static files. There is no need for additional configuration for static files in development.

However, in production, static files should not be served by Django itself. Instead, a web server (e.g., Nginx, Apache) should serve these files for better performance.

Join the conversation