Tādi lasītāji kā jūs palīdz atbalstīt MUO. Veicot pirkumu, izmantojot saites mūsu vietnē, mēs varam nopelnīt filiāles komisiju.
Bez dinamiskas maršrutēšanas būtu grūti pārvietoties tīmekļa lapās. Jums būs jāievada katras pārlūkprogrammas apmeklētās lapas pilns ceļš. Kāda briesmīga lietotāja pieredze.
Dinamiskie vienotie resursu meklētāji (URL) ļauj pārvietoties uz dažādām lietotnes lapām, noklikšķinot uz pogas. Django ļauj viegli izveidot dinamiskus URL. Tam ir URL konfigurācijas modulis (URLconf), kas savieno URL izteiksmes ar skatiem.
Viss URLconf kods ir Python sintaksē, kas ļauj viegli izveidot dinamiskus URL. Uzzināsim vairāk par dinamiskajiem URL, izveidojot Django projektu.
1. Izveidojiet Django projektu
Pirmkārt, izveidot Django projektu un lietojumprogramma (lietotne).
Nosauciet savu lietotni Boma pulkstenis. Lietotne apkopos atrašanās vietu, aprakstu un iedzīvotāju numurus no dažādiem rajoniem. Izveidojiet modeli ar nosaukumu Kaimiņvalsts. Izmantojiet modeli, lai datubāzē pievienotu informāciju par apkaimēm. Uzziniet, kā izveidot modeļus Django un datubāze, ja neesat pazīstams.
Pēc tam izveidojiet skatu funkciju apkaimēm.
2. Izveidojiet skata funkciju
Programmā Django skati ir Python funkcijas, kas pieņem HTTP pieprasījumus un atgriež atbildes. Tīmekļa lapā, ko nodrošina Django, skati veic dažādus uzdevumus un uzdevumus.
Lai izpildītu skatu, tas ir jāizsauc, izmantojot URL. URL ir unikāls ceļš uz resursu tīmeklī. Resurss var būt HTML lapa, attēls vai API galapunkts.
Izveidojiet URL, kas izgūst apkārtnes datus, pamatojoties uz nodotajiem parametriem. Lai to izdarītu, varat izmantot primārā atslēga (pk) vai Identifikācija (id) lai izgūtu informāciju. Lai to izdarītu, izmantosit vienu veidni.
Varat izveidot skatus, definējot tos failā ar nosaukumu views.py lietotnes mapē. Sāciet, importējot renderēt funkcija no Django, lai parādītu datus URL. Importējiet arī Kaimiņvalsts modelis no modeļi.py.
no django.shortcuts imports renderēt
no .modeļi imports apkārtne
Pēc tam izveidojiet skata funkciju ar nosaukumu mājas kas parāda visas mājas veidnes apkārtnes. The NeighborHood.objects.all() funkcija saņem datus par visiem apkaimēm no datu bāzes.
defmājas(pieprasījums):
apkaimes = NeighbourHood.objects.all()
atgriezt renderēšanu (pieprasīt, "mājaslapa.html", {'apkaimes':apkaimes})
Izveidojiet arī skatīšanas funkciju join_hood kas parādīs apkārtnes informāciju. The NeighbourHood.objects.get (id=id) funkcija pieprasa datus atbilstoši ID. Pēc tam informācija tiek atveidota uz veidnes.
defjoin_hood(pieprasījums, id):
apkaime = NeighbourHood.objects.get (id=id)
atgriezt renderēšanu (pieprasīt, 'join_hood.html', {'apkārtne':neighborhood})
Vēlāk, pārejot uz apkaimi, varēsit redzēt tā profila informāciju.
3. Izveidojiet dinamisko URL
Tagad varat izveidot dinamisku URL jūsu izveidotajai skata funkcijai.
no django.urls imports ceļš
no. imports skatījumi
no django.conf imports iestatījumi
no django.conf.urls.static importsstatisks
nodjango.contrib.statiskie faili.urlsimportsstaticfiles_urlpatternsurlpatterns = [
ceļš ('mājas', views.home, name='mājas'),
ceļš ('join_hood/<str: id>/', views.join_hood, name='join_hood'),
]
jaiestatījumi.DEBUG:
URL raksti += statisks(iestatījumi. MEDIA_URL, document_root = iestatījumi. MEDIA_ROOT)
Importēt ceļš no Django URL, lai izveidotu skatu ceļus. Pēc tam importējiet skata funkcijas no views.py.
The join_hood URL ir vietturis leņķa iekavās:. Tas tver šo URL daļu un nosūta uz skatu.
Leņķa iekavās parasti ir iekļauta pārveidotāja specifikācija. Specifikācija var būt virkne (str) vai vesels skaitlis (int). Django arī piedāvā gliemeža, ceļš, vai universāli unikāli identifikatori (uuid). Specifikācija ierobežo mainīgā veidu vai rakstzīmju skaitu, kas tiek nodotas skata URL.
Nosaukuma piešķiršana vietrāžiem URL palīdzēs tos identificēt veidnēs.
The statisks un statiskie faili imports parāda statiskus failus URL ceļos. Uzziniet vairāk par to, kā strukturēt URL parametrus oficiālajā Django dokumentācija.
4. Pievienojiet URL veidnei
Kad URL ir pievienota skatīšanas funkcija, izveidojiet HTML veidni, lai parādītu datus. Jūs nosaucat veidni join_hood.html.
{% pagarina "base.html" %}
{% slodze statisks %}
{% bloķēt saturu %}
<div klase="karte mb-3" stils ="maksimālais platums: atbilst saturam;">
<div klase="rinda g-0">
<div klase="col-md-4">
<div klase="col-md-8">
<div klase="karte-body">
<h5 klase="kartes nosaukums"> Laipni lūdzam!</h5>
<p klase="kartītes teksts pt-4"> Vārds: {{neighbourhood.name}}</lpp>
<p klase="kartītes teksts pt-4"> Atrašanās vieta: {{neighbourhood.location}}</lpp>
<p klase="kartītes teksts pt-4"> Apraksts: {{neighbourhood.description}}</lpp>
<p klase="kartītes teksts pt-4"> Veselība Tālr.:{{neighbourhood.health_tell}}</lpp>
<p klase="kartītes teksts pt-4"> Policijas numurs: {{neighbourhood.police_number}}</lpp>
<p klase="kartītes teksts pt-4"> Iedzīvotāji: {{apkaime. Skaits}}</lpp>
</div>
</div>
</div>
</div>
</div>
{% endblock %}
Izveidojiet join_hood veidni lietotņu mapē, lai parādītu apkārtnes datus. Pirmkārt, pagariniet base.html veidni ar stila lapām (bootstrap), ko izmantosit veidnes stila veidošanai. Pēc tam renderējiet mainīgos, kas lapā parādīs informāciju.
Pēc tam izveidojiet a mājaslapa.html veidne, kurā tiks parādīti visi rajoni.
{% pagarina 'base.html' %}
{% slodze statisks %}
{% bloķēt saturu %}
<div klase="konteiners" stils ="krāsa: melna;">
<img src="{{neighborhood.hood_logo.url}}" klase="card-img-top" alt="{{user.neighborhood.name}}"><div klase="rinda">
{% apkaimēm mikrorajonos %}
<div klase="col-md-4">
<div klase="karte mb-4" stils ="Minimālais augstums: 340 pikseļi">
<img src="{{neighborhood.hood_logo.url}}" klase="card-img-top" alt="{{user.hood.name}}"><div klase="karte-body">
<h5 klase="kartes nosaukums">
{{neighborhood.name}}
({{neighborhood.location}})
<span klase="ml-4">{{apkaime. Count}} biedrs{{neighborhood.members.count|pluralize}}</span>
</h5><p klase="kartīte-teksts">{{neighborhood.description}}</lpp>
<p klase="kartīte-teksts">{{apkaime.biedrs. Skaits}}</lpp>
<a href="{% url 'join_hood' Neighbourhood.id %}" klase="btn btn-primary btn-sm">Pievienojieties Hudam</a>
</div>
</div>
</div>
</div>
</div>
{% endblock %}
Sākumlapā atveidojiet visu informāciju, ko vēlaties parādīt par apkaimēm. Sākumlapā jūs pievienosit pogu un enkura tagu. Enkura tagam ir URL nosaukums un apkaimes ID.
Noklikšķinot, poga pāriet uz šī ID apkārtni. Mājas veidne tiek parādīta vietrādī URL http://127.0.0.1:8000/home/. Zemāk redzamais attēls parāda šo lapu:
5. Pārbaudiet dinamisko maršrutēšanu
Tagad varat pārbaudīt, vai dinamiskā maršrutēšana darbojas veidnē. Kad noklikšķināt uz pievienoties kapuci pogu, tas pāriet uz join_hood veidne. The join_hood veidnē tiek parādīta profila informācija par jūsu atlasīto apkaimi.
Jūs redzēsit arī apkaimes ID, kas parādīts pārlūkprogrammas URL http://127.0.0.1:8000/join_hood/2/
Tas parādīsies, kā parādīts zemāk:
Apsveicam! Jūs esat izveidojis dinamisku URL.
Kāpēc izmantot Django URL?
Dinamiskie URL ir svarīga tīmekļa lietojumprogrammu funkcija. Django ļauj viegli izveidot vietrāžus URL atbilstoši jūsu vajadzībām. Tas novērš ierobežojumus, ko varētu saistīt ar citiem ietvariem.
URLconf modulis ir pilns ar resursiem, kas atbalsta Django URL izveidi. Tas arī atvieglo statisko failu apkalpošanu veidnēs un uzlabo kļūdu apstrādi.
Django ir citas funkcijas, kas paredzētas aizmugurprogrammu optimizēšanai. Tas automatizē lietotāju autentifikāciju, satura administrēšanu un vietņu kartes, kā arī citas funkcijas.