# Introduction ```{toctree} :caption: Basics :maxdepth: 3 :hidden: self installation components ``` ```{toctree} :caption: Components :maxdepth: 3 :hidden: views templates actions child-components django-models ``` ```{toctree} :caption: Features :maxdepth: 3 :hidden: direct-view validation redirecting loading-states dirty-states partial-updates polling visibility messages ``` ```{toctree} :caption: Advanced :maxdepth: 3 :hidden: javascript queue-requests custom-morphers ``` ```{toctree} :caption: Misc :maxdepth: 3 :hidden: cli settings ``` ```{toctree} :caption: Info :maxdepth: 3 :hidden: faq changelog troubleshooting architecture code-of-conduct PDF docs Code repo Sponsor ``` ```{toctree} :caption: API :maxdepth: 3 :hidden: api/django_unicorn/index ``` Want to add some component-based magic to your front-end, but don't need the overhead of a complete JavaScript front-end framework? `Unicorn` revolutionizes the way your users interact with your Django app! With `Unicorn`, you can create stunningly spiffy pages without ever leaving Python or your beloved Django codebase. `Unicorn` is a reactive component framework that enhances your Django views by seamlessly making AJAX calls in the background and dynamically updates the HTML DOM. It's like magic, but better! `Unicorn` is leading the charge in bringing a component-based developer experience to Django. Join the `Unicorn` community today and unlock the power of reactivity!

Here are a few reasons to consider `Unicorn`. 1. **Reactive Components**: With `Unicorn`, you can create reactive components that dynamically update the HTML DOM without the need for complex JavaScript. This makes it easier to build interactive web pages and enhances the user experience. 2. **Seamless Integration**: `Unicorn` progressively enhances your Django views. This means you can seamlessly integrate Unicorn into your existing Django codebase without disrupting your current workflow. 3. **Component-Based Design**: `Unicorn` brings the benefits of component-based design to the Python ecosystem, making it easier to build complex applications and enabling more efficient development. 4. **Improved Performance**: By using AJAX calls to update the DOM, `Unicorn` reduces the need for full page reloads, which can result in improved performance and faster load times. 5. **Familiarity**: With `Unicorn`, you don't need to learn a complicated front-end frameworks to create fancy interactive components. Instead, you can use the familiar Django syntax and templates to build your front-end components. ## Related projects `Unicorn` stands on the shoulders of giants, in particular [morphdom](https://github.com/patrick-steele-idem/morphdom) which is integral for merging DOM changes. ### Inspirational projects in other languages - [Livewire](https://laravel-livewire.com/), a full-stack framework for the PHP web framework, Laravel. - [LiveView](https://github.com/phoenixframework/phoenix_live_view), a library for the Elixir web framework, Phoenix, that uses websockets. - [StimulusReflex](https://docs.stimulusreflex.com), a library for the Ruby web framework, Ruby on Rails, that uses websockets. - [Hotwire](https://hotwire.dev), "is an alternative approach to building modern web applications without using much JavaScript by sending HTML instead of JSON over the wire". Uses AJAX, but can optionally use websockets. ### Full-stack framework Python packages - [Reactor](https://github.com/edelvalle/reactor/), a port of Elixir's `LiveView` to Django. Especially interesting for more complicated use-cases like chat rooms, keeping multiple browsers in sync, etc. Uses Django channels and websockets to work its magic. - [Flask-Meld](https://github.com/mikeabrahamsen/Flask-Meld), a port of `Unicorn` to Flask. Uses websockets. - [Sockpuppet](https://sockpuppet.argpar.se/), a port of Ruby on Rail's `StimulusReflex`. Requires Django channels and websockets. - [Django inertia.js adapter](https://github.com/zodman/inertia-django) allows Django to use inertia.js to build an SPA without building an API. - [Hotwire for Django](https://github.com/hotwire-django) contains a few different repositiories to integrate [Hotwire](https://hotwire.dev) with Django. - [Lona](https://lona-web.org/) is a web application framework, designed to write responsive web apps in full Python. - [ReactPy](https://reactpy.dev/) is a port of ReactJS to Python. Fully compatible with all ReactJS components. - [django-async-include](https://github.com/diegojromerolopez/django-async-include) load HTML via AJAX. #### Comparison | Repo | Django | Flask | AJAX | Websockets | Version | Stars | | :------------------------------------------------------------- | :----: | :---: | :--: | :------------: | :------------------------------------------------------------------------------------------: | ------------------------------------------------------------------------------------------------------------------ | | [Unicorn](https://github.com/adamghill/django-unicorn) | ✔ | | ✔️ | | ![PyPI version](https://img.shields.io/pypi/v/django-unicorn?label=%20&style=flat-square) | ![GitHub Repo stars](https://img.shields.io/github/stars/adamghill/django-unicorn?label=%20&style=flat-square) | | [Reactor](https://github.com/edelvalle/reactor/) | ✔️ | | | ✔️ | ![PyPI version](https://img.shields.io/pypi/v/django-reactor?label=%20&style=flat-square) | ![GitHub Repo stars](https://img.shields.io/github/stars/edelvalle/reactor?label=%20&style=flat-square) | | [Sockpuppet](https://github.com/jonathan-s/django-sockpuppet) | ✔️ | | | ✔️ | ![PyPI version](https://img.shields.io/pypi/v/django-sockpuppet?label=%20&style=flat-square) | ![GitHub Repo stars](https://img.shields.io/github/stars/jonathan-s/django-sockpuppet?label=%20&style=flat-square) | | [Flask-Meld](https://github.com/mikeabrahamsen/Flask-Meld) | | ✔️ | | ✔️ | ![PyPI version](https://img.shields.io/pypi/v/flask-meld?label=%20&style=flat-square) | ![GitHub Repo stars](https://img.shields.io/github/stars/mikeabrahamsen/Flask-Meld?label=%20&style=flat-square) | | [ReactPy](https://github.com/reactive-python/reactpy) | ✔️ | ✔️ | | ✔️ | ![PyPI version](https://img.shields.io/pypi/v/reactpy?label=%20&style=flat-square) | ![GitHub Repo stars](https://img.shields.io/github/stars/reactive-python/reactpy?label=%20&style=flat-square) | | [Turbo Django](https://github.com/hotwire-django/turbo-django) | ✔️ | | | ✔️ for streams | ![PyPI version](https://img.shields.io/pypi/v/turbo-django?label=%20&style=flat-square) | ![GitHub Repo stars](https://img.shields.io/github/stars/hotwire-django/turbo-django?label=%20&style=flat-square) | ### Django component packages - [django-components](https://github.com/EmilStenstrom/django-components/), which lets you create "template components", that contains both the template, the Javascript and the CSS needed to generate the front end code you need for a modern app. - [django-component](https://gitlab.com/Mojeer/django_components), which provides declarative and composable components for Django, inspired by JavaScript frameworks. - [django-page-components](https://github.com/andreyfedoseev/django-page-components), a minimalistic framework for creating page components and using them in your Django views and templates. - [slippers](https://mitchel.me/slippers/), helps build reusable components in Django without writing a single line of Python. - [django_slots](https://github.com/nwjlyons/django_slots) allows multiline strings to be captured and passed to template tags. ### Django packages to integrate lightweight frontend frameworks - [django-htmx](https://github.com/adamchainz/django-htmx) which has extensions for using Django with [htmx](https://htmx.org/).