Modèles d'URL Django : Comprendre le TypeError : la vue doit être appelable
Pour les versions de Django 1.10 et suivantes, un message d'erreur spécifique peut apparaître lorsque définition des modèles d'URL : TypeError : la vue doit être un appelable ou une liste/tuple dans le cas de include(). Cette erreur se produit lorsque vous tentez de spécifier des vues sous forme de chaînes dans des modèles d'URL, une pratique couramment utilisée dans les versions antérieures de Django.
Solution :
Pour résoudre cette erreur, il est nécessaire de mettre à jour votre urls.py pour inclure la vue réelle appelable. Cela nécessite d'importer la vue dans votre fichier urls.py. Par exemple :
from django.conf.urls import include, url from django.contrib.auth.views import login from myapp.views import home, contact urlpatterns = [ url(r'^$', home, name='home'), url(r'^contact/$', contact, name='contact'), url(r'^login/$', login, name='login'), ]
Solution alternative :
Si vous avez un grand nombre de vues, les importer individuellement peut devenir gênant. Une autre approche consiste à importer le module de vues depuis votre application :
from django.conf.urls import include, url from django.contrib.auth import views as auth_views from myapp import views as myapp_views urlpatterns = [ url(r'^$', myapp_views.home, name='home'), url(r'^contact/$', myapp_views.contact, name='contact'), url(r'^login/$', auth_views.login, name='login'), ]
L'utilisation d'alias tels que myapp_views et auth_views évite les collisions de noms de vues lors de l'importation de vues à partir de plusieurs applications.
Supplémentaire Informations :
Pour des informations plus complètes sur les modèles de répartition d'URL, reportez-vous à la documentation officielle du répartiteur d'URL Django :
[Documentation du répartiteur d'URL Django](https://docs.djangoproject. com/en/stable/topics/http/urls/)
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!