Add documentation and source

Added documentation, source and extra files.
This commit is contained in:
2025-07-02 20:26:50 +02:00
parent 4fc1d36a10
commit e3ebf6bf4f
295 changed files with 24986 additions and 0 deletions

View File

@ -0,0 +1,52 @@
---
title: Django
author: Steve Kossouho
---
# Traduction d'un projet Django (I18N)
----
## Traduction dans le code Django
Pour marquer certaines chaînes dans une application comme étant traduisibles, il suffit de les passer comme arguments de la fonction `gettext_lazy`. Par convention, on importe la fonction en lui donnant l'alias `_`.
```python
from django.utils.translation import gettext_lazy as _
_("String to translate") # dans la langue de `LANGUAGE_CODE`
```
----
## Traduction dans les templates
Pour accéder aux tags spécifiques à la traduction, vous devez charger les templatetags de l'application `i18n` :
```djangotemplate
{% load i18n %}
```
----
![Traduction dans les templates](assets/images/translation-template-examples.png)
----
## Commandes pour la traduction
Dans le répertoire de l'application à traduire :
- `django-admin makemessages -l fr` : fichier pour traducteur
- `django-admin compilemessages -l fr` : traductions compilées
----
## Bénéficier automatiquement de la traduction
Pour que Django affiche vos pages dans la langue de votre navigateur, il faut ajouter dans `MIDDLEWARE` une entrée `"django.middleware.locale.LocaleMiddleware"`.
Le middleware récupère depuis les en-têtes HTTP les langues préférées du navigateur, et si possible, active la première langue dont une traduction existe. Cela nécessite donc que le navigateur soit configuré pour préférer l'affichage des pages dans votre langue préférée.
:::notes
Faire la démo des langues préférées du navigateur avec Firefox
:::