⊗ppPmSDRSP 446 of 447 menu

რამდენიმე პარამეტრი PHP-ის ძრავის მარშრუტებში

დავუშვათ, რომ ახლა ჩვენს საიტზე არის კატეგორიები და გვერდები, რომლებიც ეკუთვნის ამ კატეგორიებს. მოდით შევქმნათ ცხრილი კატეგორიებით:

categories
id slug name
1 first-category name1
2 second-category name2

და ცხრილი გვერდებით:

pages
id slug title content category_id
1 my-first-page title1 <div> content1 </div> 1
2 my-second-page title2 <div> content2 </div> 1
3 my-third-page title3 <div> content3 </div> 2

ჩვენს საიტზე ჩვენ ვუშვებთ, რომ სხვადასხვა კატეგორიის გვერდების slug-ები ემთხვევა ერთმანეთს. ეს ნიშნავს, რომ URL-ში ჩვენ ჯერ უნდა მივუთითოთ კატეგორიის slug, შემდეგ კი გვერდის slug ასეთი სქემით: /page/:category/:page, სადაც ორწერტილებით მითითებულია ადგილები, რომლებშიც იქნება ცვალებადი პარამეტრები.

მოდით დავწეროთ მარშრუტები ჩვენი საიტისთვის:

<?php $route = '^/page/(?<catSlug>[a-z0-9_-]+)/(?<pageSlug>[a-z0-9_-]+) '; if (preg_match("#$route#", $url, $params)) { $page = include 'view/page/show.php'; } $route = '^/page/(?<catSlug>[a-z0-9_-]+) '; if (preg_match("#$route#", $url, $params)) { $page = include 'view/page/category.php'; } $route = '^/ '; if (preg_match("#$route#", $url, $params)) { $page = include 'view/page/all.php'; } ?>

პირველი მარშრუტის დამმუშავებელში ჩვენ ვაჩვენებთ მოთხოვნილ გვერდს:

<?php $catSlug = $params['catSlug']; $pageSlug = $params['pageSlug']; $query = "SELECT pages.title, pages.content FROM pages LEFT JOIN category ON category.id=pages.category_id WHERE pages.slug='$pageSlug' AND category.slug='$catSlug'"; $res = mysqli_query($link, $query) or die(mysqli_error($link)); $page = mysqli_fetch_assoc($res); return $page; ?>

მეორე მარშრუტის დამმუშავებელში ჩვენ ვაჩვენებთ მითითებული კატეგორიის გვერდების სიას:

<?php $catSlug = $params['catSlug']; $query = "SELECT pages.slug, pages.title FROM pages LEFT JOIN category ON category.id=pages.category_id WHERE category.slug='$catSlug'"; $res = mysqli_query($link, $query) or die(mysqli_error($link)); for ($data = []; $row = mysqli_fetch_assoc($res); $data[] = $row); $content = ''; foreach ($data as $page) { $content .= ' <div> <a href="/page/' . $catSlug . '/' . $page['slug'] . '">' . $page['title'] . '</a> </div> '; } $page = [ 'title' => 'კატეგორიის ' . $catSlug . ' ყველა გვერდის სია', 'content' => $content ]; return $page; ?>

დავუშვათ, გაქვთ საიტი ქალაქებით და ქვეყნებით. დავუშვათ, მისამართზე / გამოდის ყველა ქვეყნის სია, მისამართზე /:country გამოდის პარამეტრში მითითებული ქვეყნის ქალაქების სია, ხოლო მისამართზე /:country/:city მითითებული ქალაქის აღწერა.

ქართული
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語Қазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
ვებსაიტის მუშაობის, ანალიტიკისა და პერსონალიზაციისთვის ვიყენებთ ქუქი-ფაილებს. მონაცემთა დამუშავება ხდება Კონფიდენციალურობის პოლიტიკის შესაბამისად.
ყველას მიღება პარამეტრები უარყოფა