# django-components [![PyPI - Version](https://img.shields.io/pypi/v/django-components)](https://pypi.org/project/django-components/) [![PyPI - Python Version](https://img.shields.io/pypi/pyversions/django-components)](https://pypi.org/project/django-components/) [![PyPI - License](https://img.shields.io/pypi/l/django-components)](https://github.com/django-components/django-components/blob/master/LICENSE/) [![PyPI - Downloads](https://img.shields.io/pypi/dm/django-components)](https://pypistats.org/packages/django-components) [![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/django-components/django-components/tests.yml)](https://github.com/django-components/django-components/actions/workflows/tests.yml) ###
[Read the full documentation](https://django-components.github.io/django-components/latest/)
> ⚠️ Attention ⚠️ - We migrated from `EmilStenstrom/django-components` to `django-components/django-components`. > > **Repo name and documentation URL changed. Package name remains the same.** > > Report any broken links links in [#922](https://github.com/django-components/django-components/issues/922). Django-components is a package that introduces component-based architecture to Django's server-side rendering. It aims to combine Django's templating system with the modularity seen in modern frontend frameworks. A component in django-components can be as simple as a Django template and Python code to declare the component: ```htmldjango title="calendar.html"
Today's date is {{ date }}
``` ```py title="calendar.py" from django_components import Component class Calendar(Component): template_file = "calendar.html" ``` Or a combination of Django template, Python, CSS, and Javascript: ```htmldjango title="calendar.html"
Today's date is {{ date }}
``` ```css title="calendar.css" .calendar { width: 200px; background: pink; } ``` ```js title="calendar.js" document.querySelector(".calendar").onclick = function () { alert("Clicked calendar!"); }; ``` ```py title="calendar.py" from django_components import Component class Calendar(Component): template_file = "calendar.html" js_file = "calendar.js" css_file = "calendar.css" ``` Alternatively, you can "inline" HTML, JS, and CSS right into the component class: ```py from django_components import Component class Calendar(Component): template = """
Today's date is {{ date }}
""" css = """ .calendar { width: 200px; background: pink; } """ js = """ document.querySelector(".calendar").onclick = function () { alert("Clicked calendar!"); }; """ ``` ## Features 1. 🧩 **Reusability:** Allows creation of self-contained, reusable UI elements. 2. 📦 **Encapsulation:** Each component can include its own HTML, CSS, and JavaScript. 3. 🚀 **Server-side rendering:** Components render on the server, improving initial load times and SEO. 4. 🐍 **Django integration:** Works within the Django ecosystem, using familiar concepts like template tags. 5. ⚡ **Asynchronous loading:** Components can render independently opening up for integration with JS frameworks like HTMX or AlpineJS. Potential benefits: - 🔄 Reduced code duplication - 🛠️ Improved maintainability through modular design - 🧠 Easier management of complex UIs - 🤝 Enhanced collaboration between frontend and backend developers Django-components can be particularly useful for larger Django projects that require a more structured approach to UI development, without necessitating a shift to a separate frontend framework. ## Quickstart django-components lets you create reusable blocks of code needed to generate the front end code you need for a modern app. Define a component in `components/calendar/calendar.py` like this: ```python @register("calendar") class Calendar(Component): template_file = "template.html" def get_context_data(self, date): return {"date": date} ``` With this `template.html` file: ```htmldjango
Today's date is {{ date }}
``` Use the component like this: ```htmldjango {% component "calendar" date="2024-11-06" %}{% endcomponent %} ``` And this is what gets rendered: ```html
Today's date is 2024-11-06
``` ###
[Read the full documentation](https://django-components.github.io/django-components/latest/)
... or jump right into the code, [check out the example project](https://github.com/django-components/django-components/tree/master/sampleproject)) ## Release notes Read the [Release Notes](https://github.com/django-components/django-components/tree/master/CHANGELOG.md) to see the latest features and fixes. ## Community examples One of our goals with `django-components` is to make it easy to share components between projects. If you have a set of components that you think would be useful to others, please open a pull request to add them to the list below. - [django-htmx-components](https://github.com/iwanalabs/django-htmx-components): A set of components for use with [htmx](https://htmx.org/). Try out the [live demo](https://dhc.iwanalabs.com/). - [djc-heroicons](https://pypi.org/project/djc-heroicons/): A component that renders icons from [Heroicons.com](https://heroicons.com/). ## Contributing and development Get involved or sponsor this project - [See here](https://django-components.github.io/django-components/dev/overview/contributing/) Running django-components locally for development - [See here](https://django-components.github.io/django-components/dev/overview/development/)