ASP.NET MVC: История одного проекта Поиск (часть 10)
Содержание
ASP.NET MVC: История одного проекта "Готовимся к старту" (часть 1)
ASP.NET MVC: История одного проекта "Всё ради данных" (часть 2)
ASP.NET MVC: История одного проекта "Шаблоны и внешний вид" (часть 3)
ASP.NET MVC: История одного проекта "Еще немного классов" (часть 4)
ASP.NET MVC: История одного проекта "UI - всё для пользователя" (часть 5)
ASP.NET MVC: История одного проекта "UI - Добавление экспоната" (часть 6)
ASP.NET MVC: История одного проекта "UI - Редактирование экспоната" (часть 7)
ASP.NET MVC: История одного проекта "Обработка ошибок" (часть 8)
ASP.NET MVC: История одного проекта "Фильтрация" (часть 9)
ASP.NET MVC: История одного проекта "Поиск" (часть 10)
ASP.NET MVC: История одного проекта "Облако тегов" (часть 11)
ASP.NET MVC: История одного проекта "Главная страница" (часть 12)
Задача
Мне требуется создать универсальный поиск, с возможностью расширения списка типов сущностей, по которым можно осуществлять поиск. Поиск должен осуществляться через autocomplete-поле на всех страницах сайта. Для этого надо все типы сущностей: экспонат, лента, метка "засунуть" в один список, который через AJAX будет возвращать JSON-объекты в выпадающий список.
Поле ввода запроса
Куда положить поле ввода, это риторический вопрос. Конечно же в шаблон (_LayoutExtended), чтобы поле было доступно с любой страницы сайта (отключение поиска на избранных страницах, например, ввод логина и пароля, пока не будем обсуждать, но это в планах). Я создам UserControl, который будет отображать само поле ввода и содержать скрипты (у нас же ajax), которые будут обслуживать это поле:
Вот код разметки:
@Html.TextBox("searcher", null, new { data_autocomplete = @Url.Content("/site/search/") }) @Html.ScriptBlock( @<script type="text/javascript" src="@Url.Content("/scripts/search.mvc.helpers.js")"> </script>) @Html.ScriptBlock( @<script type="text/javascript" src="@Url.Content("/scripts/jquery.blockUI.js")"> </script>)
Как видно из разметки есть поле ввода и два скрипта: один - работает с поле ввода, второй - "прячет" от пользователя контент сайта, на время, пока происходит перенаправление на выбранный из списка элемент. Показывать второй скрипт я не буду, вы можете найти подобного рода скриптов на jQuery огромное количество в интернете или, в конце-концов, написать свой скрипт с таким функционалом. А вот первый я создам в папке Scripts, он пока пустой займемся им позже.
Откуда контент-то? Дык, JsonResult есть!
Поместить метод поиска Search разумнее всего в основной для сайта контролер, чтобы доступность метода не перекрывалась необходимостью авторизации и аутентификации. Значит в моем случае, в контролле SiteController:
public JsonResult Search() { return Json("", JsonRequestBehavior.AllowGet); }
Пока он тоже "пустой". А прежде чем начать писать что-то, я бы хотел объяснить, что я собираюсь сделать. Разложить, так сказать, по полочкам вариант реализации.
SearchItem базовый класс для поиска
Чтобы получить возможность наполнить выпадающий список autocomplete, надо чтобы сущности были одного типа (я не буду сейчас говорить про Tuple), иначе придется выдавать из метода Search (JsonResult) несколько списков, а потом еще и обрабатывать их по разному, в зависимости от полей и свойств, которые есть в этих классах. Я упрощу себе задачу, создам один абстрактный базовый класс SearchItem. От этого класса унаследую все классы, которые и будут иметь возможность отображаться в списке при поиске:
/// <summary>
/// Базовый класс для всех сущностей,
/// от которого должна быть унаследована сущность
/// чтобы иметь возможность поиска по ней
/// </summary>
public abstract class SearchItem {
/// <summary>
/// Идентификатор
/// </summary>
public abstract int Id { get; }
/// <summary>
/// Название CSS стиля для отображения
/// </summary>
public abstract string CssClass { get; }
/// <summary>
/// Наименование типа,
/// используется для перенаправления
/// пользователя
/// </summary>
public abstract string TypeName { get; }
/// <summary>
/// Заголовок, отображается в списке autocomplete
/// </summary>
public abstract string Title { get; }
}Я постарался описать в summary всю информацию по свойствам. Надеюсь, всё понятно. Теперь унаследую от этого класса новый класс ExhibitSearch:
/// <summary> /// Класс используется при формировании /// результатов поиска по сущности Exhibit /// </summary> public class ExhibitSearch : SearchItem { Exhibit Model; public ExhibitSearch(Exhibit model) { this.Model = model; } public override int Id { get { return this.Model.Id; } } public override string Title { get { return Model.Title; } } public override string CssClass { get { return "exhibitsearch"; } } public override string TypeName { get { return "экспонат:"; } } }
Обратите внимание на CssClass, я создал этот стиль в файле каскадных стилей. В нем ничего особенного, просто хочется чтобы заголовок был под цвет шаблона в выпадающем списке. Такие стили я создал для каждого из наслеников класса SearchItem. А теперь класс для меток для поиска:
/// <summary> /// Класс используется при формировании /// результатов поиска по сущности Tag /// </summary> public class TagSearch : SearchItem { Tag Model; public TagSearch(Tag model) { this.Model = model; } public override int Id { get { return Model.Id; } } public override string Title { get { return Model.Name; } } public override string CssClass { get { return "tagsearch"; } } public override string TypeName { get { return "метка:"; } } }
И напоследок, остался еще класс для поиска по сущности "Лента":
/// <summary> /// Класс используется при формировании /// результатов поиска по сущности Tag /// </summary> public class LentaSearch : SearchItem { Lenta Model; public LentaSearch(Lenta model) { this.Model = model; } public override int Id { get { return Model.Id; } } public override string Title { get { return Model.Content.CutLongText(100, "..."); } } public override string CssClass { get { return "lentasearch"; } } public override string TypeName { get { return "лента:"; } } }
Пока хватит новых классов. Если потребуется осуществлять поиск по какой-либо еще сущности, я добавлю ее позже.
Метод Search
Возвращаемся к методу поиска:
public JsonResult Search(string term) { List<SearchItem> result = new List<SearchItem>(); var exhibits = exhibitRepository.All.Where(x => x.Title.Contains(term) || x.Content.Contains(term)) .Take(5) .ToList() .Select(x => new ExhibitSearch(x)); if (exhibits.Any()) { result.AddRange(exhibits); } var tags = tagRepository.All .Where(x => x.Name.Contains(term)) .Take(5) .ToList() .Select(x => new TagSearch(x)); if (tags.Any()) { result.AddRange(tags); } var lentas = lentaRepository.All .Where(x => x.Content.Contains(term)) .Take(5) .ToList() .Select(x => new LentaSearch(x)); if (lentas.Any()) { result.AddRange(lentas); } return Json(result.OrderBy(x => x.Title).ToArray(), JsonRequestBehavior.AllowGet); }
Находим все записи в разных типах сущностей, которые подходят по критерию отбора и складываем их в один список (Можно было бы использовать Linq и в частности Uinion(), но я сделал "по старинке"). И если теперь есть метод, можно написать скрипт, который будет его вызывать в файле search.mvc.helpers.js:
$(document).ready(function () { var url = $("#searcher").attr("data-autocomplete"); $("#searcher").autocomplete({ minLength: 2, source: function (request, response) { $.getJSON(url, { term: request.term }, response); }, select: function (event, ui) { block(); if (ui.item.CssClass == 'tagsearch') window.location = '/museum?t=' ui.item.Title; if (ui.item.CssClass == 'exhibitsearch') window.location = '/museum/show/' ui.item.Id; if (ui.item.CssClass == 'lentasearch') window.location = '/lenta?t=' ui.item.Title; return false; } }).data('autocomplete')._renderItem = function (ul, item) { return $('<li style="font-size:.7em; max-width:700px;"></li>') .data('item.autocomplete', item) .append('<a><span class="searchtype">' item.TypeName '</span><span class="searchtitle ' item.CssClass '">' item.Title '</span></a>') .appendTo(ul); }; });
Стоит еще показать как это работает. Autocomplete-поле теперь выбрасывает вот такой спискок:
Я набрал в строке поиска "го" и это результат работы поиска. Мне осталось только предложить скачать проект и попрощаться. Спасибо за внимание - пишите комментарии.
Подробнее: http://feedproxy.google.com/~r/blogmusor/~3/UpMOEN7bMTQ/85
|
Содержание ASP.NET MVC: История одного проекта Готовимся к старту (часть 1)ASP.NET MVC: История одного проекта Всё ради данных (часть 2)ASP.NET MVC: История одного проекта Шаблоны и внешний вид |
РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2025-12-02 » Когда ошибка молчит: как бессмысленные сообщения ломают пользовательский опыт
- 2025-12-02 » 9 лучших бесплатных фотостоков
- 2025-12-02 » UTM-метки: ключевой инструмент аналитики для маркетолога
- 2025-12-02 » ПромоСтраницы Яндекса: Что такое и для чего служит
- 2025-12-02 » Метатеги для сайта: исчерпывающее руководство по Title, Description, Canonical, Robots и другим тегам
- 2025-11-26 » Оценка эффективности контента: превращаем информационный балласт в рабочий актив
- 2025-11-26 » 10 причин высокого показателя отказов на сайте
- 2025-11-26 » Когда и зачем обновлять структуру сайта
- 2025-11-26 » Скрытые демотиваторы: как мелочи разрушают эффективность команды
- 2025-11-26 » Зачем запускать MVP и как сделать это грамотно?
- 2025-11-20 » Половина российских компаний сократит расходы на транспорт и маркетинг в 2026 году
- 2025-11-20 » Перенос сайта с большим количеством ссылок
- 2025-11-20 » Перелинковка сайта: Что такое и как ее использовать
- 2025-11-20 » Критерии выбора SEO-специалиста и подрядчика для продвижения сайта
- 2025-11-20 » Применение искусственного интеллекта в рекламных агентствах: комплексное исследование трендов 2025 года
- 2025-11-19 » Геозапросы по-новому: как покорить локальное SEO с помощью ИИ
- 2025-11-14 » Консалтинг: сущность и ключевые направления
- 2025-11-14 » Онлайн-формы: универсальный инструмент для сбора обратной связи
- 2025-11-14 » Факторы конверсии органического трафика
- 2025-11-14 » Планирование рекламного бюджета: самостоятельный подход
- 2025-11-14 » Авторизация на сайте: как выбрать решение для удержания клиентов и сохранения продаж
- 2025-11-13 » Эффективные методы стимулирования клиентов к оставлению положительных отзывов
- 2025-11-13 » Налоговая реформа — 2026: грядущие изменения для предпринимателей
- 2025-11-13 » Альтернативы мессенджерам: что выбрать вместо Telegram и WhatsApp
- 2025-11-13 » Маркировка рекламы для начинающих: полное руководство по требованиям ЕРИР
- 2025-11-13 » ИИ не отберет вашу работу — её займет специалист, владеющий искусственным интеллектом
- 2025-10-29 » Как оценить эффективность работы SEO-специалиста: практическое руководство для маркетологов и владельцев бизнеса
- 2025-10-29 » Киберспорт как маркетинговый инструмент: стратегии привлечения геймеров
- 2025-10-29 » Как говорить с аудиторией о сложном
- 2025-10-29 » Что такое доказательства с нулевым разглашением (ZKP) и их роль в блокчейне
Мудрость приносит следующие три плода: дар хорошо мыслить, хорошо говорить и хорошо поступать Демокрит - (около 460 до н.э.- около 360 до н.э.) - древнегреческий философ |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.

Мы создаем практически любые сайты от продающих страниц до сложных, высоконагруженных и нестандартных веб приложений! Наши сайты это надежные маркетинговые инструменты для успеха Вашего бизнеса и увеличения вашей прибыли! Мы делаем красивые и максимально эффектные сайты по доступным ценам уже много лет!
Комплексный подход это не просто продвижение сайта, это целый комплекс мероприятий, который определяется целями и задачами поставленными перед сайтом и организацией, которая за этим стоит. Время однобоких методов в продвижении сайтов уже прошло, конкуренция слишком высока, чтобы была возможность расслабиться и получать \ удерживать клиентов из Интернета, просто сделав сайт и не занимаясь им...
Мы оказываем полный комплекс услуг по сопровождению сайта: информационному и техническому обслуживанию и развитию Интернет сайтов.
Контекстная реклама - это эффективный инструмент в интернет маркетинге, целью которого является увеличение продаж. Главный плюс контекстной рекламы заключается в том, что она работает избирательно.