Как наладить поиск по сайту?

15.07.2024

Как наладить поиск по сайту?

Компоненты, необходимые для организации текстовго поиска по сайту доступны в базовом комплекте поставке, но не на каждом сайте они настроены. То, что описано ниже, можно использовать именно в том виде, как описано, но желательно, результат оформить в стиле Вашего сайта.

Важно понимать, что введёная поискова строка будет искаться именно в том виде, в котором она будет введена. Морфология не учитывается. Порядок слов также не будет изменён. Чтобы обойти эти ограничения, можете фразы с другим порядком слов и в других падежах, временах, спряжениях и т.п. указывать в каких-либо скрытых полях, которые не будут видны на сайте. И указать эти поля как те, по которым также должен вестись поиск. Это будет описано ниже...

Создание формы поиска

Форму поиска (обычный HTML-код) можно написать прямо в шаблонах в элементе HTML-код веб-страницы, но это не самый продуманный вариант, если, вдруг, Вам понадобится быстро изменить один и тот же код сразу в нескольких шаблонах. Лучше создать одно редактируемое поле, в котором будет HTML-код формы. И уже это поле можно вставить во всех (нужных) шаблонах. Так в случае изменения кода в форме, он автоматически изменится во всех (нужных) шаблонах.

  1. Перейдите в раздел Контент \ Редактируемые поля (можно в другой подраздел раздела Контент)
  2. Нажмите Добавить новую запись
  3. Укажите любое название, например, Форма поиска
  4. Укажите любой ID, например, search-form (дальше будет ориентироваться именно на такой ID)
  5. Выберите шаблон Многострочное поле без редактора и нажмите Добавить. Если такого шаблона нет (был удалён), то ознакомьтесь с тем, как создать шаблон и вставить в него элемент Многострочное поле без редактора.
  6. Вставьте в поле Содержимое поля без редактора (название может быть другое), код указанный ниже, скорректируйте его под свои нужды и сохраните изменения.

Пример кода:

<form method="post" action="/search/">
  <input placeholder="Поиск..." type="text" name="search" value="{plugin:current_SearchText}" />
  <input type="submit" value="Найти">
</form>

Для тега form, можно изменить следующее:

  • method - может быть, как post, так и get. Во втором случае поисковый запрос будет доступен в адресной строке браузера
  • action - здесь должен быть указан адрес страницы, на которой будут располагаться результаты поиска. В нашем случае это страница с ID search. Далее будем ориентироваться именно на него, хотя ограничений на ID страницы с результатами поиска нет.

Поле, в котором будет вводиться поисковый запрос, обязательно должно иметь значение search в свойстве name. Изменить можно следующее:

  • type - может быть любым, подходящим в Вашем случае, например, number. Но в большинстве случаев лучше оставить text или search.
  • value - можно оставить пустым или написать любой другой текст, который сразу же будет отображаться в поле для ввода поискового запроса. Чтобы автоматически отобразить здесь только что введённый поисковый запрос, напишите {plugin:current_SearchText}

Других ограничений или обязательных требований нет. Для отправки формы можете использовать, как <input type="submit"><input type="image"><button type="submit"></button>, так и любой другой, допустимый в HTML, вариант.

Естественнно, код формы нужно оформить в стиле Вашего сайта, если он сильно выделяется на фоне других элементов интерфейса wink

Код формы поиска, например, имеющей вид {plugin:content;id:search-form;value:multistringfield_1_value}, будет виден ниже поля Содержимое поля без редактора (название может быть другое). Скопируйте его и вставьте в элемент HTML-код веб-страницы во всех нужных шаблонах. Если код формы не виден, то на панели инструментов нажмите кнопку Подсказки и помощники по вставке плагинов и свойств: показать.

Создание списка результатов поиска

Список результатов поиска отображается также, как любой другой список или любое меню - с помощью плагина универсального меню.

  1. Перейдите в раздел Справочники \ Оформление меню нажмите Добавить новую запись
  2. Нажмите Добавить новую запись
  3. Укажите любое название, например, Результаты поиска
  4. Укажите любой ID, например, search-results (дальше будет ориентироваться именно на такой ID) и нажмите Добавить

Далее в самом простом случае достаточно заполнить только поле HTML-код обычной записи, например, таким кодом:

<p>
  <a href="{content_url_value}">{content_name}</a>
</p>

Чуть более сложный вариант, в котором также будет отображён путь к найденным страницам при условии, что вариант меню с ID path существует (не было удалён):

<p>
  <a href="{content_url_value}">{content_name}</a>
  <br />
  {plugin:menu;id:path;select:path;factor:{content_id}}
</p>

Если учесть, что результатов поиска может быть много, то лучше разбивать список на несколько подстраниц. Тогда также нужно заполнить следующие поля, например, следующими кодами:

  • HTML-код до списка подстраниц: <p><a href="{menu_subpage_firsturl}" title="В начало списка">«</a>
  • HTML-код после списка подстраниц: <a href="{menu_subpage_lasturl}" title="В конец списка">»</a></p>
  • HTML-код обычного элемента списка подстраниц: <a href="{menu_subpage_url}">{menu_subpage}</a>
  • HTML-код активного элемента списка подстраниц: <a href="{menu_subpage_url}">{menu_subpage}</a>

Код меню тоже желательно оформить в стиле Вашего сайта, если он сильно отличается от других элементов интерфейса. Ограничений или обязательных требований по части HTML-кода - нет.

Осталось только вставить код для вызова списка результатов поиска в основной текст страницы c ID search (либо с другим ID, который указан в форме поиска), либо в HTML-код её шаблона.

Код может быть, например, таким:

{plugin:menu;id:search-result;search:{plugin:current_SearchText};inlist:20;maxsubpages:10;factor:.;select:children-all;sort:name}

Вы можете использовать другие параметры для вызова плагина универсального меню. Важно обратить внимание на следующие:

  • id: должен быть равен ID списка (меню), созданного для отображения результатов поиска
  • types: здесь можно через запятую перечислить типы, записи, которых Вам нужны. Например, если нужны новости и товары, то напишите news,goods. Если ничего не указывать, то поиск будет вестись по записям всех типов.
  • select: в большинстве случаев больше других вариантов подойдёт all (поиск будет вестись по всей струтуре сайта). Также часто может быть полезен вариант children (для поиска только по непосредственным подразделам того, что указано в factor). И также может быть полезен вариант children-all (для поиска по всем подразделам того, что указано в factor). Последний вариант даёт самую высокую нагрузку на веб-сервер, поэтому не является предпочтительным, если другие варианты дают схожий результат.
  • search: здесь должна быть указана поисковая фраза. Чтобы автоматически указать здесь то, что было введено в форме поиска, напишите {plugin:current_SearchText}.
  • search-cols: здесь через запятую можно указать поля, по которым будет вестись поиск. По умолчанию используется такое значение: id,name,seo_title,seo_description,seo_keywords,maintext_value. Вы также можете добавить в этот список другие поля, в том числе те скрытые поля, про которые написано в начале данной статьи.
  • factor: не будет иметь значение, если в select указано all. Для других, описанных выше, вариантов здесь можно указать ID той страницы, подразделы которой нам важны в поиске, например, catalog для поиска товаров и их категорий. Если нужно указать самый верх структуры (для поиска по всем её подразделам), укажите точку - .
  • inlist: позволит не выводить огромное количество результатов поиска на одной странице, а разбить список на несколько подстраниц, ограничив каждую максимально допустимым, указанным здесь количеством записей
  • maxsubpages: позволит ограничить количество подстраниц с результатами поиска на случай, если их будет слишком много
  • sort: даст возможность организовать один из вариантов сортировки

 


CMS Zion WebEngine является бесплатной системой. Развивается за счёт рекламы, помощи веб-студии #webZion и других спонсоров.

 

Будем рады, если Вы поддержите нас любой суммой, а также поделитесь идеями на счёт каких-либо улучшений и доработок для CMS...

 

Заранее, большое, спасибо

 

Блог обновлений

Zion WebEngine X8.11.13
  • Доработан плагин универсального меню (спасибо Новый стандарт):
    • Устранены недочёты при проверке данных на пустоту

Zion WebEngine Меню/Списки/Навигация Плагины

Zion WebEngine X8.11.12
  • Доработан класс для управления изображениями:
    • Устранены недочёты при автоматической корректировке структуры базы данных
  • Доработаны плагин и класс галереи:
    • Расширен функционал для автоматического создания эскизов для слайдов:
      • Можно выбирать, какую часть слайда сохранить при создании эскиза, если он слишком широкий или слишком высокий (аналогично тому, как это ранее было сделано для изображений)

Zion WebEngine Zion Gallery Административный интерфейс База данных/Таблицы данных Галереи/Слайды Изображение Классы Плагины Эскизы

Zion WebEngine X8.11.10
  • Доработаны классы для управления контентом и изображениями:
    • Расширен функционал для автоматического создания эскизов:
      • Можно выбирать, какую часть изображения сохранить при создании эскиза, если он слишком широкий или слишком высокий
    • В административном интерфейсе теперь под изображениями отображаются их адреса, аналогично тому, как это было сделано ранее для слайдов галерей

Zion WebEngine Административный интерфейс Галереи/Слайды Изображение Классы Контент/Контентные единицы Эскизы

Zion WebEngine X8.11.09
  • Доработан вспомогательный класс для управления изображениями (спасибо Единый Центр Недвидимости):
    • Устранены недочёты при создании эскизов

Zion WebEngine Изображение Классы Эскизы

Zion WebEngine X8.11.08
  • Доработан плагин универсального меню (спасибо Moto-Retail18):
    • Оптимизирован поиск текста:
      • При поиске в одном поле или в нескольких запускаются разные алгоритмы, оптимизированные под разные задачи
    • Устранены некоторые недоработки при обработке условий
  • Доработан класс для управления контентом (спасибо Единый Центр Недвидимости):
    • Устранена вероятность несовместимости с некоторыми компонентами, функционал которых будет расширен в предстоящих обновлениях
  • Доработан класс для управления текущими данными:
    • Улучшена конвертация поисковых запросов в нужную кодировку
  • Доработан класс для управления HTML-кодом веб-страницы:
    • Расширен список доступных условий:
      • В том числе HTML-код можно оформить по-разному в зависимости от того, ввёл ли что-нибудь пользователь в строку поиска

Zion WebEngine HTML-код веб-страницы Классы Кодировки/Наборы символов Контент/Контентные единицы Меню/Списки/Навигация Обновления CMS Плагины Поиск текста Текущие данные Условия

Zion WebEngine X8.11.07
  • Доработаны галереи (спасибо Единый Центр Недвидимости):
    • Устранены вероятность некорректного удаления слайда вместе с файлом:
      • Соответствующая кнопка отображается только, если для слайда выбран файл с изображением
      • Обработка удаления запускается только, если соответствующий файл не является папкой (такое возможно)
        • Применимо не только к изображениям, но и к их эскизам
      • При массовом удалении слайдов вместе с файлами также реализована аналогичная защита
    • Улучшены подсказки к свойствам слайдов:
      • Теперь они отображаются не после списка слайдов, а под каждым слайдом

Zion Gallery Галереи/Слайды Изображение Помощники/Мастеры/Инструкции/Подсказки Свойства Файлы/Папки Эскизы

Zion WebEngine X8.11.05
  • Доработан вспомогательный класс для управления изображениями (спасибо Единый Центр Недвидимости):
    • Устранена вероятность создания пустых папок для эскизов в случае, если изображение не было выбрано пользователем:
      • Применимо для элемента "Изображение"
      • Применимо для слайдов в галереях

Zion WebEngine Галереи/Слайды Доступы/Пользователи Изображение Классы Файлы/Папки Элементы Эскизы

Zion WebEngine X8.11.02
  • Доработаны галереи:
    • Расширен список доступных условий:
      • В том числе теперь каждый слайд можно оформить по-разному в зависимости от того:
        • Какой у него ID
        • Заполнено ли указанное поле
        • Имеет ли указанное поле указанное значение
        • Последний ли это слайд
        • Равно ли ID слайда указаннной переменной в куках
        • Есть ли в указанном массиве куков элемент с указанным именем
    • Реализована возможность обработки пользовательских параметров (в том числе отсутствующих в документации), переданных в плагин галереи при обращении к нему
  • Доработана навигация по меню/спискам
    • Устранены неточности в подсказке к условию IS_EXISTS_IN_COOKIE_ARRAY_имямассива_имяэлемента??истина::ложь
      • Теперь оно доступно не только до оформления блока, но и после

Zion WebEngine Zion Gallery Галереи/Слайды Куки Меню/Списки/Навигация Плагины Помощники/Мастеры/Инструкции/Подсказки Условия

Zion WebEngine X8.11.01
  • Доработаны галереи:
    • Расширен список доступных условий:
      • В том числе теперь блоки слайдов можно оформить по-разному в зависимости от их порядкового номера:
  • Доработана навигация по меню/спискам
    • Расширена область действия условия IS_HAS_BLOCK_NUMBER_номер??истина::ложь
      • Теперь оно доступно не только до оформления блока, но и после

Zion WebEngine Zion Gallery Галереи/Слайды Меню/Списки/Навигация Условия

Zion WebEngine X8.10.31
  • Доработаны галереи:
    • Реализована возможность использовать порядковый номер слайда при его оформлении в галерее
    • Дополнены подсказки по использованию свойств галерей и слайдов:
      • Добавлены новые описания
      • Устранены опечатки в старых описаниях
    • Расширен список доступных условий:
      • В том числе теперь каждый слайд можно оформить по-разному в зависимости от того:
        • Чётный этот слайд или нечётный
        • Если стоимость всех товаров в корзине меньше указанной суммы
          • Доступно при наличии Zion Catalog
    • Расширена область действия условия IS_PLUGINPARAM_имя_значение??истина::ложь:
      • Теперь оно доступно не только в оформлении слайдов, но и в оформлении начала и конца галереи, а также в случае отсутствия слайдов

Zion Gallery Галереи/Слайды Корзина для заказов Помощники/Мастеры/Инструкции/Подсказки Свойства Условия

Zion WebEngine X8.10.29
  • Доработаны класс для управления навигацией и плагин универсального меню:
    • Расширен список доступных условий:
      • В том числе условие IS_HAS_NUMBER>номер??истина::ложь позволяет задать особое оформление для элемента списка с номером выше указанного значения
    • Расширена область действия некоторых условий:
      • В том числе условие IS_PLUGINPARAM_имя_значение??истина::ложь теперь можно использовать до и после списка, а нетолько при оформлении элементов списка (спасибо Новый стандарт)

Zion WebEngine Классы Меню/Списки/Навигация Плагины Условия

Zion WebEngine X8.10.26
  • Доработан класс для управления галереями:
    • Реализована возможность удалить сразу все слайды из нужной галереи:
      • Также при наличии доступа к файл-менеджеру можно удалить все слайды вместе с файлами изображений:
        • Если эти файлы используются в других слайдах любых других галерей, то эти слайды также будут удалены автоматически
    • Устранён недочёт при массовом добавление изображений в галерею:
      • При включенной опции "Не дублировать, если уже добавлено" слайды не добавлялись, если соответствующие изображения уже использовались в других галереях
  • Доработаны некоторые JS-скрипты
  • Доработан класс для управления пользователями (спасибо Новый стандарт):
    • Реализован плагин для отображения имени активного или конкретно указанного пользователя

Zion WebEngine Zion Gallery Галереи/Слайды Доступы/Пользователи Классы Плагины Файл-менеджер Файлы/Папки

Zion WebEngine X8.10.24
  • Доработан класс для управления пользователями (спасибо Новый стандарт):
    • Реализована возможность после обработки формы для пользователей запустить дополнительный обработчик

Zion WebEngine Доступы/Пользователи Классы Обработчики Формы для пользователей

Zion WebEngine X8.10.22
  • Доработан класс для управления файлами и папками (спасибо Новый стандарт):
    • Упрощено управление файлами, которые могут быть загружены пользователями

Zion WebEngine Доступы/Пользователи Классы Файлы/Папки

Zion WebEngine X8.10.19
  • Доработаны классы для управления пользователями и вкладками (спасибо Новый стандарт):
    • Реализована возможность автоматически добавлять необходимые вкладки из совместимых с данной функцией классов при правке пользователей
    • Реализована возможность автоматически добавлять необходимые поля в базу данных из совместимых с данной функцией классов при сохранении пользователей

Zion WebEngine База данных/Таблицы данных Вкладки Доступы/Пользователи Классы

Zion WebEngine X8.10.16
  • Доработан класс для управления пользователями (спасибо Color House):
    • Теперь при входе в административный интерфейс и при восстановлении пароля администратора вместо онлайн-консультанта можно перейти на данный Портал поддержки

Zion WebEngine Административный интерфейс Доступы/Пользователи Классы Онлайн-консультант

Zion WebEngine X8.10.15
  • Доработан класс для управления многоязычностью (спасибо Анвизор):
    • Улучшена совместимость с Яндекс.Вебмастер и другими аналогичными сервисами

Zion Multi-Lang Классы Многоязычность/Языки

Zion WebEngine X8.10.11
  • Доработан класс для управления пользователями (спасибо Новый стандарт):
    • Упрощена обработка некоторых свойств в формах для пользователей
  • Доработан элемент "Число":
    • Добавлен новый плагин, позволяющий перед указанным числом добавить необходимое количество нулей

Zion WebEngine Zion Catalog Доступы/Пользователи Классы Плагины Свойства Формы для пользователей Число Элементы

Zion WebEngine X8.10.10
  • Доработан класс для управления файлами и папками (спасибо Новый стандарт):
    • Добавлен новый плагин, который автоматически добавляет к адресу указанного файла временную метку последнего изменения данного файла:
      • Это позволит автоматически очищать кэш для часто изменяемых CSS-, JS- и других файлов
  • Доработан драйвер оболочки:
    • Расширен список символов, доступных для указания в параметрах при обращении к плагинам

Zion WebEngine Драйверы Классы Кэш/Кеш Плагины Файлы/Папки

Zion WebEngine X8.10.09
  • Доработан класс для управления XML-данными (спасибо Moto-Retail-18):
    • При предпросмотре данных для импорта учтено, что этих данных может быть очень много:
      • Устранена вероятность появления ошибки при очень длительной загрузке

Zion Catalog XML/RSS/1С/YML Импорт/Экспорт Классы