404 страница: различия между версиями
Перейти к навигации
Перейти к поиску
Olga (обсуждение | вклад) (Новая страница: «Создадим отдельную страницу в нашей структуре: Файл:Screenshot 3 UMI CMS - Добавление страницы.pn...») |
Olga (обсуждение | вклад) |
||
| (не показано 6 промежуточных версий этого же участника) | |||
| Строка 3: | Строка 3: | ||
[[Файл:Screenshot 3 UMI CMS - Добавление страницы.png|обрамить|без]] | [[Файл:Screenshot 3 UMI CMS - Добавление страницы.png|обрамить|без]] | ||
| − | + | Уберем признак отображения в меню, поставим признак "Исключить из поиска". В настройках сайта в созданном специальном поле для 404 страницы выберем эту страницу: | |
| − | [[Файл:Screenshot | + | [[Файл:Screenshot 15 UMI CMS - Редактирование.png|без]] |
| − | + | Шаблон 404 страницы notfoud.phtml модифицируем: | |
| − | [[ | + | <pre> |
| + | <?php | ||
| + | $notFound = $variables['settings']->notfound; | ||
| + | if (!empty($noFound)) $page = $notFound[0]; | ||
| + | else $page = false; | ||
| + | ?> | ||
| + | <section> | ||
| + | <div class="container"> | ||
| + | <div class="row"> | ||
| + | <div class="col-12"> | ||
| + | <?php if ($page): ?> | ||
| + | <h1 umi:element-id="<?= $page->id ?>" umi:field-name="h1" umi:empty="<?= $this->translate('empty_page_name') ?>"><?= $page->h1 ?></h1> | ||
| + | </div> | ||
| + | <div class="col-12"> | ||
| + | <div umi:element-id="<?= $page->id ?>" umi:field-name="content" umi:empty="<?= $this->translate('empty_page_content') ?>"><?= $page->content ?></div> | ||
| + | <?php else: ?> | ||
| + | <h1><?= $variables['header'] ?></h1> | ||
| + | <?php endif; ?> | ||
| + | </div> | ||
| + | </div> | ||
| + | </div> | ||
| + | </section> | ||
| + | </pre> | ||
| + | |||
| + | При выборе страницы 404 в дереве можно было заметить, что интерфейс позволяет выбрать несколько страниц. Значит, в результате получим массив объектов. Выбираем первый элемент. Главное, вставить проверки, чтобы не получить ошибку. Ну и конечно, можно в настройках сделать поле для 404 ошибки обязательным, чтобы редактор сайта был вынужден его заполнить. | ||
| + | |||
| + | Если же ничего не нашли, то выводим заголовок из $variables, который подставила UMI CMS. | ||
Текущая версия на 14:40, 3 ноября 2020
Создадим отдельную страницу в нашей структуре:
Уберем признак отображения в меню, поставим признак "Исключить из поиска". В настройках сайта в созданном специальном поле для 404 страницы выберем эту страницу:
Шаблон 404 страницы notfoud.phtml модифицируем:
<?php
$notFound = $variables['settings']->notfound;
if (!empty($noFound)) $page = $notFound[0];
else $page = false;
?>
<section>
<div class="container">
<div class="row">
<div class="col-12">
<?php if ($page): ?>
<h1 umi:element-id="<?= $page->id ?>" umi:field-name="h1" umi:empty="<?= $this->translate('empty_page_name') ?>"><?= $page->h1 ?></h1>
</div>
<div class="col-12">
<div umi:element-id="<?= $page->id ?>" umi:field-name="content" umi:empty="<?= $this->translate('empty_page_content') ?>"><?= $page->content ?></div>
<?php else: ?>
<h1><?= $variables['header'] ?></h1>
<?php endif; ?>
</div>
</div>
</div>
</section>
При выборе страницы 404 в дереве можно было заметить, что интерфейс позволяет выбрать несколько страниц. Значит, в результате получим массив объектов. Выбираем первый элемент. Главное, вставить проверки, чтобы не получить ошибку. Ну и конечно, можно в настройках сделать поле для 404 ошибки обязательным, чтобы редактор сайта был вынужден его заполнить.
Если же ничего не нашли, то выводим заголовок из $variables, который подставила UMI CMS.

