Пусть теперь у нас на сайте есть категории и страницы, принадлежащие этим категориям. Давайте сделаем таблицу с категориями:
id | slug | name |
---|---|---|
1 | first-category | name1 |
2 | second-category | name2 |
И таблицу со страницами:
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 |
На нашем сайте мы разрешаем, чтобы слаги
страниц из разных категорий совпадали. Это
значит, что в урле мы должны указать сначала
слаг категории, а потом слаг страницы вот
по такой схеме: /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'";
$result = mysqli_query($link, $query) or die(mysqli_error($link));
$page = mysqli_fetch_assoc($result);
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'";
$result = mysqli_query($link, $query) or die(mysqli_error($link));
for ($data = []; $row = mysqli_fetch_assoc($result); $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
описание указанного города.