ASP.NET MVC: История одного проекта Главная страница (часть 12)
Содержание
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)
Задача на этот раз
Не знаю как у других программистов, а меня обычно получается заниматься главной страницей сайта в последнюю очередь. В силу того, что она является неким начало пути и содержит по немногу контента со всех остальных разделов. У меня на главной странице должны появиться: лента анекдотов и музей экспонатов. И те и другие должны отображать последние добавленные записи. В начале цикла статей, я писал о том, что хочу на главной странице показывать и ленту отбора и уже отобранные экспонаты:
Экспонаты главной
Я покажу как я сделал UserControl для экспонатов, для ленты отбора нужно проделать всё то же самое,а значит дублировать и без того простой код не имеет смыслаю Для начала в контролере Museum создаем метод Preview:
[ChildActionOnly] public ActionResult Preview() { var model = exhibitRepository.AllIncluding(x=>x.Hall,x=>x.Tags) .OrderByDescending(x => x.Id) .Take(10) .ToViewModels(); return PartialView(model); }
Обратите внимание на аттрибут ChildActionOnly, который говорит, что данный метод может быть вызван только как PartialView, хотя точнее сказать, может вызываться только из другого метода (ActionResult). Есть метод контролера, значить должно быть и представление (View). У меня уже существую два представления в папке Shared/Templates для экспоната (Exhibit). Но я создам еще одно, еще более простое, чем два предыдущие существующие:
@model Calabonga.Mvc.Humor.Models.ShowExhibitViewModel <div class="item"> <div class="info">#<b>@Model.Id</b> от @Html.DisplayFor(model=>Model.CreatedAt)</div> <div class="content"> @Html.Raw( Model.Content.CutLongText( 280, @Html.ActionLink( ">>", "show", new { id = Model.Id }, new { @class = "more backblue rounded" }).ToString() ) ) </div> </div>
Осталось теперь вызвать этом метод и приладить данные к этому представлению. На странице (в представлении) Index контролера Site добавим вызов метода Preview из контролера Museum как ChildAction. Приведу разметку целиком, а важное выделю жирным шрифтом:
@{ ViewBag.Title = "Музей юмора 2.0"; } <div class="clear" style="margin-top: 12px;"> <div id="toplenta" style="width: 470px; float: left; text-align: right; padding: 6px;"> @Html.ActionLink("лента отбора экспонатов", "index", "lenta") </div> <div id="topmuseum" style="width: 470px; float: right; padding: 6px;"> @Html.ActionLink("отбранные экспонаты", "index", "museum") </div> </div> <div id="main"> <div class="clear"> <div style="width: 470px; float: left; padding: 6px;"> @{ Html.RenderAction("preview", "lenta"); } @Html.ActionLink("лента юмора", "index", "lenta", null, new { @class = "button" }) </div> <div style="width: 470px; float: right; padding: 6px;"> @{ Html.RenderAction("preview", "museum"); } @Html.ActionLink("отборный юмор", "index", "museum", null, new { @class = "button" }) </div> </div> </div>
Обратите внимание на специфический вызов метода html-помощника Html.RenderAction. Для вызова этого метода испозуются фигурные скобки.
Так как у меня уже готов код UserControl и для ленты отбора, я так же добавил и этот контрол для отрисовки на странице. Оба они отмечены в разметке жирным шрифтом.
В качестве заключения к циклу статей
На этом публичная работа над серией статей "История одного проекта" закончена. На самом деле предстоит сделать очень многое, например:
- WCF-сервис чтобы новой версии сайта продолжила работать программа "Музей юмора" для Windows Phone, описание которой есть в блоге;
- плагин для Google-гаджета (а может и не буду, потому что Google заявил, что iGoogle с первого января работать перестанет);
- плагин для Yandex-гаджета;
- ТОП-ссылок, взамен того что есть сейчас на сайте;
- страницу случано отображающую экспонаты;
- страница с топ-просмотров по каждой категории и в целом по музею;
- модуль на Silverlight, для администрирования музея и ленты;
- и много других мелочей...
Описанные пункты не так сильно относятся (или даже вообще не относятся) к разработке на ASP.NET MVC, и поэтому я думаю, вам не будет интересен этот материал. Но если что-то из указанного вас заинтересовало - отпишитесь в комментариях.
Надеюсь, материал был полезным. Спасибо всем кто поучавствовал в развитии проекта своими комментариями, советами и конструктивной критикой.
Подробнее: http://feedproxy.google.com/~r/blogmusor/~3/0ta2mpunhK0/87


Поделиться статьей:
Акция: Закажи любой сайт до окончания акции и получи скидку + подбор семантического ядра + поисковую оптимизацию сайта Это позволит Вам получать еще больше трафика и соответственно клиентов из Интернета!
До конца акции осталось
0
5
4
3
2
1
0
0
9
8
7
6
5
4
3
2
1
0
0
5
4
3
2
1
0
0
9
8
7
6
5
4
3
2
1
0
0
9
8
7
6
5
4
3
2
1
0
0
9
8
7
6
5
4
3
2
1
0
|
Узнайте подробности акции у менеджеров компании по телефонам: 8-924-200-7194 г.Хабаровск 8-800-550-9899 Бесплатно по России (с 2:30 до 11:30 по Мск) |
Новые статьи и публикации
- 2021-02-24 » Как попасть в Clubhouse и что там делать: гид по новой соцсети
- 2021-02-24 » ТОП-10 онлайн-консультантов для сайта
- 2021-02-16 » UX-копирайтинг: как небольшие тексты существенно повышают продажи
- 2021-02-08 » Яндекс.Кью: особенности сервиса и его польза для бизнеса
- 2021-02-01 » Покупательское поведение пользователей: как оно изменилось за последнее время?
- 2021-01-22 » PHP и регулярные выражения: азы для новичков
- 2021-01-22 » Факторы ранжирования-2021
- 2021-01-19 » Вопросы юзабилити: на что обратить внимание в 2021 году?
- 2021-01-12 » Алгоритм YATI: новая разработка Яндекса
- 2020-12-29 » DdoS-атаки: суть и способы защиты от них
- 2020-12-21 » Оплата за конверсии в Яндекс.Директе: в чём выгода и как проходит подключение?
- 2020-12-14 » Предновогодняя суета: как привлечь клиентов и активизировать продажи?
- 2020-12-03 » Ведение блога: на своём сайте или на специальной платформе?
- 2020-11-30 » Виджеты для веб-сайтов: влияние кнопок на продажи
- 2020-11-30 » CRM: что это и как помогает бизнесу?
- 2020-11-13 » Тепловые карты сайта: особенности и возможности для продвижения
- 2020-11-11 » Яндекс.Клиенты: всё о новых возможностях георекламы
- 2020-10-27 » Описания товаров для интернет-магазинов: секреты успешных продаж
- 2020-10-27 » Увеличиваем мобильный трафик: 10 способов привлечь новых клиентов
- 2020-10-14 » Определение CMS сайта: как это сделать?
- 2020-10-13 » Сайты-агрегаторы: сотрудничать или бороться за ТОП?
- 2020-10-05 » Интернет-магазин в Instagram: как его открыть?
- 2020-09-28 » Интернет-тролли: как с ними бороться и не подмочить репутацию?
- 2020-09-17 » Bing: обновление для веб-мастеров
- 2020-09-15 » Подключение платформы Яндекс.Диалоги на веб-сайт
- 2020-09-07 » Яндекс.Вордстат: как это работает?
- 2020-08-27 » Настройка аудиорекламы в социальных сетях: как её выполнить?
- 2020-08-21 » Текст для карточки товара: как сделать идеальное описание?
- 2020-08-17 » Сайты-визитки: какими они должны быть?
- 2020-08-10 » Оценка страниц Google: как это работает?
Предоставляем полный комплекс услуг по созданию, обслуживанию и продвижению сайтов по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.