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

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 X7.12.09
  • Доработана возможность изменения заголовков, передаваемых веб-сервером (спасибо MKV Pro):
    • В том числе теперь значительно проще сменить тип контента с обычного "text/html" на "application/xml" или на любой другой
      • Так значительно проще создавать не только HTML-, но и XML-сайты и различные XML-выдачи, например RSS, YML и т.д.
    • Также доступно более простое указание альтернативной кодировки символов, например, универсальной utf-8, вместо стандартной для CMS windows-1251
      • При этом не только корректируется заголовок от сервера, но и происходит автоматическая конвертация всего контента в указанную кодировку
    • Новый функционал в внедрён в плагин универсального меню, но оказывает влияние на весь комплекс CMS
      • В помощнике по вставке плагина универсального меню добавлены необходимые подсказки
    • Из комплекта поставки удалён плагин RSS, так как его функционал теперь полностью доступен в других компонентах новой платформы
  • Отключена автоматическая подстановка некоторых HTML-тегов
    • Так управление HTML-кодом веб-страницы будет более гибкое
  • Внедрена поддержка многоуровневого ЧПУ
    • Количество подразделов в человеко-понятном URL не ограничено
    • CMS автоматически определяет, который раздел необходимо открыть, по последнему подразделу в списке, независимо от того, указан ли корректный список надразделов
    • Управление данной возможностью, а также задание канонического URL будет реализовано в ближайших обновлениях

Zion WebEngine HTML-код веб-страницы XML/RSS/1С/YML Адрес (URL)/ЧПУ/Переадресация Веб-сервер/Хостинг Кодировки/Наборы символов Меню/Списки/Навигация Обновления CMS Плагины Платформа Помощники/Мастеры/Инструкции/Подсказки

Zion WebEngine X7.12.08
  • Доработан класс для работы с HTML-кодом веб-страницы
    • Теперь в HTML-коде веб-страниц, как и в случае с меню/списками доступно указание условий, в зависимости от выполнения или невыполнения которых HTML-код может быть разным. Доступны следующие условия:
      • Если у данного раздела есть подразделы
      • Если у данного раздела соответствующий индентификатор (ID)
      • Если у данного раздела указанное поле не заполнено или равно 0 (спасибо Moto-Retail18)
      • Если у данного раздела соответсвующий тип
      • Если данный раздел связан с записью с указанным идентификатором

Zion WebEngine HTML-код веб-страницы Меню/Списки/Навигация Связи Типы Условия

Zion WebEngine X7.11.27
  • Доработано меню администратора для данного пакета:
    • Создан раздел Инструменты, в который перемещены некоторые подразделы раздела Опции
  • Класс Catalog переименован в Import, так как это больше соответствует его сути
  • Доработан класс для работы с Корзиной заказов
    • Устранена вероятность возникновения ошибок на некоторых веб-серверах
  • Доработано создание записей по умолчанию
    • Реализовано автоматическое создание связей между товарами и аксессуарами (для примера)
    • Расширен список автоматически создаваемых меню и списков
      • В том числе товаров, аксессуаров и связей между ними
        • Также реализованы сразу несколько способов добавления товаров/аксессуаров в корзину (для примера)
          • Ещё несколько вариантов будут добавлены в ближайших обновлениях
      • Некоторые ранее создаваемые меню теперь организованы более продуманно
    • Доработан HTML-код некоторых шаблонов по умолчанию
    • Созданы новые шаблоны по умолчанию
      • В том числе для товаров и аксессуаров (по умолчанию)
    • Реализовано создание нескольких товаров и аксессуаров по умолчанию, а также связей между ними (для примера)

Zion WebEngine Zion Catalog HTML-код веб-страницы Веб-сервер/Хостинг Импорт/Экспорт Классы Корзина для заказов Меню/Списки/Навигация Меню администратора Обновления CMS Сайт-каталог Связи Шаблоны контента

Zion WebEngine X7.11.24
  • Доработан класс для работы с Корзиной заказов в интернет-магазине (спасибо Moto-Retail18):
    • Реализована возможность опционально использовать альтернативную реакцию на добавление товара в Корзину
      • Посетитель может быть отправлен не только на ту страницу, на которой он был до этого, но и на то же самое место на этой странице.
      • Также доступно отображение уведомления в браузерном окне Alert (JavaScript)
    • Классическая реакция доступна и используется по умолчанию
      • Она более гибкая и позволяет настроить перенаправление посетителя в любое явно определённое место на сайте
      • При это выводится обычное уведомление - не в отдельном окне, а на настраиваемом месте на странице

Zion Catalog Интернет-магазин Классы Корзина для заказов Уведомления

Zion WebEngine X7.11.23
  • Доработаны класс для управения навигацией и плагин универсального меню (спасибо Moto-Retail18):
    • Доступно для использования новое условие
      • Теперь можно особым образом оформлять тот или иной пункт в меню или в списке в зависимости от того, заполнено ли у него указанное поле

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

Zion WebEngine X7.11.18
  • Доработаны класс дя управления навигацией и плагин универсального меню (спасибо Феникс):
    • Теперь в меню можно использовать ещё больше переданных в меню параметров, для того, чтобы более гибко управлять вызовом вложенных в меню

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

Zion WebEngine X7.11.13
  • Доработан класс для работы с каталогом (спасибо Феникс):
    • Устранена проблема с пагинацией в Интерфейсе администратора, которая могла возникнуть при отсутствии необходимых настроек

Zion WebEngine Классы Пагинация/Подстраницы Сайт-каталог

Zion WebEngine X7.11.11
  • Расширен функционал класса для работы с текущими данными (спасибо Moto-Retail18):
    • В частности стала доступна возможность, позволяющая после добавления товара в корзину вернуться не только на ту же страницу, но и на ту же подстраницу
      • Все необходимые параметры подставляются автоматически и только в тех случаях, когда это необходимо (это положительно влияет в том числе на SEO)

Zion WebEngine Классы Корзина для заказов Пагинация/Подстраницы Текущие данные

Zion WebEngine X7.11.05
  • Создан класс Catalog (спасибо Moto-Retail18)
    • Реализована возможность быстрого настраиваемого импорта данных (например, крупного каталога товаров)
      • Потенциально импортировать можно не только товары, но, и страницы, новости, статьи... Любой контент

Zion Catalog Импорт/Экспорт Классы Сайт-каталог

Zion WebEngine X7.11.03
  • Доработан класс для управления базой данных (спасибо Moto-Retail18)
    • Реализована фильтрация записей в административном интерфейсе:
      • Например, можно отобразить все подразделы указанного надраздела:
        • При этом во время настройки фильтра можно фильтровать сами надразделы по типам, что сокращает скорость настройки и снижает нагрузку на веб-сервер
      • В случае применения фильтра отображается соответствующее уведомление
      • Можно настраивать уже имеющуюся фильтрацию или создавать новую, удалив старую

Zion WebEngine Административный интерфейс База данных/Таблицы данных Веб-сервер/Хостинг Классы Типы Уведомления Фильтрация

Zion WebEngine X7.11.02
  • Доработан класс для управления базой данных (спасибо Moto-Retail18)
    • Реализована пагинация в административном интерфейсе
      • Настройки пагинации не будут появляться, если в списках мало записей
      • Список подстраниц не будет появляться, если для листания доступна всего одна подстраница
  • Оптимизирован дистрибутив пакета SEO Booster:
    • Удалено всё, чтобы было необходимо для поиска текста в старой платформе (в новой платформе это уже в базовой поставке)
    • Размер дистрибутива уменьшился в 2,5 раза
    • Теперь этот пакет служит только для создания условий качественной SEO-оптимизации

Zion WebEngine Zion SEO Booster Административный интерфейс База данных/Таблицы данных Классы Меню/Списки/Навигация Пагинация/Подстраницы Платформа Поиск текста

Zion WebEngine X7.11.01
  • Для нужд поиска текста доработана пагинация списков и меню

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

Zion WebEngine X7.10.31
  • Оптимизирован дистрибутив пакета Catalog:
    • Удалено всё, чтобы было необходимо для работы сайта-каталога и интернет-магазина в старой платформе
    • Размер дистрибутива уменьшился в 3,5 раза
  • В новой платформе реализован полноценный, быстрый, многофункциональный поиск текста (спасибо Moto-Retail18):
    • К результатам поиска применим весь "ассортимент" "фишек", доступных для других меню и списков

Zion WebEngine Zion Catalog Интернет-магазин Меню/Списки/Навигация Платформа Поиск текста Сайт-каталог

Zion WebEngine X7.10.28
  • Доработано формирование заказов из корзины (спасибо Moto-Retail18):
    • Теперь интернет-магазин работает целиком на новой платформе
    • Стало доступно оформление уведомлений о заказе через административный интерфейс

Zion Catalog Административный интерфейс Интернет-магазин Корзина для заказов Платформа Реакции на заказ

Zion WebEngine X7.10.27
  • Завершена работа над классом для управления корзиной (спасибо Moto-Retail18)
    • Реализован весь функционал, необходимый для работы с корзиной в новой платформе
  • Создан класс для предоставления доступа к текущим данным: позволяет более гибко настраивать каталог товаров и корзину
  • Расширен функционал плагина универсального меню:
    • Теперь с помощью него можно настраивать отображение товаров из корзины:
      • Дополнительные плагины для этого более не требуются
      • Для товаров из корзины применим весь огромный набор функционала, доступный для других меню и списков
  • Доработан помощник по вставке плагина универсального меню:
    • Дополнено описание новых доступных параметров

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

Zion WebEngine X7.10.26
  • Доработан плагин универсального меню (спасибо Moto-Retail18):
    • Добавлена возможность отображать в одном меню или списке не только непосредственные подразделы, но и все другие разделы, находящиеся глубже в структуре
  • Доработан помощник по вставке плагина универсального меню:
    • Добавлена информация о новых доступных параметрах
    • Уточнена информация об использовании других параметров
  • Доработан элемент "Число":
    • Реализованы некоторые дополнительные возможности, в том числе позволяющие использовать данный элемент в качестве цены для товара: таких элементов может быть несколько, но выбрать в качестве цены можно только один из них
  • Доработан класс для работы с контентом:
    • Расширен набор доступных функций: так внедрение нового функционала станет более быстрым
    • Улучшено кэширование: так производительность системы значительно повысится
  • Создан класс, позволяющей управлять корзиной заказов в новой платформе:
    • Работа ещё не завершена, но уже очень скоро мы сможем представить Вам новые компоненты для нового интернет-магазина

Zion WebEngine Zion Catalog Интернет-магазин Классы Контент/Контентные единицы Корзина для заказов Кэш/Кеш Меню/Списки/Навигация Плагины Платформа Помощники/Мастеры/Инструкции/Подсказки Число Элементы

Zion WebEngine X7.10.12
  • Устранена вероятность многократного дублирования одних и тех же уведомлений (спасибо Учебный Центра "Алекс")

Zion WebEngine Уведомления

Zion WebEngine X7.10.10
  • Доработана система мониторинга
    • Реализована проверка на наличие параметров для защиты от спама (спасибо Про-Отделка)

Zion WebEngine Мониторинг Спам

Zion WebEngine X7.10.09
  • Доработана система мониторинга
    • Реализована проверка на наличие параметров для корректной работы SMTP

Zion WebEngine SMTP/PHP-mail Мониторинг

Zion WebEngine X7.10.02
  • Доработан поиск текста для новой платформы (спасибо Теплодом)

Zion SEO Booster Платформа Поиск текста