Категории
Самые читаемые
ChitatKnigi.com » 🟢Компьютеры и Интернет » Базы данных » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Читать онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
1 ... 612 613 614 615 616 617 618 619 620 ... 642
Перейти на страницу:

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать

<b>  return View(car);</b>

}

Значение модели может быть передано и в &lt;partial&gt;, как показано ниже:

&lt;partial name=&quot;Partials/_CarListPartial&quot; model=&quot;@Model&quot;/&gt;

Объекты ViewBag, ViewData и TempData

Объекты ViewBag, ViewData и TempData являются механизмами для отправки представлению данных небольшого объема. В табл. 31.1 описаны три механизма передачи данных из контроллера в представление (помимо свойства Model) либо из контроллера в контроллер.

И ViewBag, и ViewData указывают на тот же самый объект; они просто предлагают разные способы доступа к данным. Еще раз взгляните на созданный ранее файл _HeadPartial.cshtml (важная строка выделена полужирным):

&lt;meta charset=&quot;utf-8&quot; /&gt;

&lt;meta name=&quot;viewport&quot; content=&quot;width=device-width, initial-scale=1.0&quot; /&gt;

<b>&lt;title&gt;@ViewData[&quot;Title&quot;] - AutoLot.Mvc&lt;/title&gt;</b>

&lt;link rel=&quot;stylesheet&quot; href=&quot;~/lib/bootstrap/dist/css/bootstrap.min.css&quot; /&gt;

&lt;link rel=&quot;stylesheet&quot; href=&quot;~/css/site.css&quot; /&gt;

Вы заметите, что в атрибуте &lt;ctitle&gt; для установки значения применяется объект ViewData. Поскольку ViewData — конструкция Razor, она предваряется символом @. Чтобы увидеть результаты, модифицируйте представление RazorSyntax.cshtml следующим образом:

@model AutoLot.Models.Entities.Car

<b>@{</b>

<b>    ViewData[&quot;Title&quot;] = &quot;RazorSyntax&quot;;</b>

<b>}</b>

&lt;h1&gt;Razor Syntax&lt;/h1&gt;

...

Теперь после запуска приложенияи перехода поссылке https://localhost:5001/Home/RazorSyntax вы увидите на вкладке браузера заголовок Razor Syntax — AutoLot.Mvc (Синтаксис Razor — AutoLot.Mvc).

Вспомогательные функции дескрипторов

Вспомогательные функции дескрипторов являются новым средством, введенным в версии ASP.NET Core. Вспомогательная функция дескриптора (tag helper) — это разметка (специальный дескриптор или атрибут в стандартном дескрипторе), представляющий код серверной стороны, который затем помогает сформировать выпускаемую HTML-разметку Они значительно совершенствуют процесс разработки и улучшают читабельность представлений MVC.

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

В отличие от вспомогательных функций HTML, которые вызываются как методы Razor, вспомогательные функции дескрипторов представляют собой атрибуты, добавляемые к стандартным HTML-элементам или автономным специальным дескрипторам. В случае использования для разработки среды Visual Studio появляется дополнительное преимущество в виде средства IntelliSense, которое отображает подсказки по встроенным вспомогательным функциям дескрипторов.

Например, показанная ниже вспомогательная функция HTML создает метку для свойства FullName заказчика:

@Html.Label(&quot;FullName&quot;,&quot;Full Name:&quot;,new {@class=&quot;customer&quot;})

В итоге генерируется следующая HTML-разметка:

&lt;label class=&quot;customer&quot; for=&quot;FullName&quot;&gt;Full Name:&lt;/label&gt;

По всей видимости, синтаксис вспомогательных функций HTML хорошо понятен разработчикам на языке С#, применяющим ASP.NET МУС и Razor. Но его нельзя считать интуитивно понятным, особенно для тех, кто имеет дело с HTML/CSS/JavaScript, но не с языком С#.

Версия в виде вспомогательной функции дескриптора выглядит так:

&lt;label class=&quot;customer&quot; asp-for=&quot;FullName&quot;&gt;Full Name:&lt;/label&gt;

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

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

Включение вспомогательных функций дескрипторов

Вспомогательные функции дескрипторов потребуется сделать видимыми любому коду, где их желательно использовать. Файл _ViewImports.html из стандартного шаблона уже содержит следующую строку:

@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers

Строка делает все вспомогательные функции дескрипторов из сборки Microsoft.AspNetCore.Mvc.TagHelpers (содержащей все встроенные вспомогательные функции дескрипторов) доступными всем представлениям на уровне каталога с файлом _ViewImports.cshtml и ниже него в иерархии каталогов.

Вспомогательная функция дескриптора для формы

 Вспомогательная функция дескриптора для формы (&lt;form&gt;) заменяет вспомогательные функции HTML с именами Html.BeginForm() и Html.BeginRouteForm(). Скажем, чтобы создать форму, которая отправляет версию действия Edit для НТТР-метода POST контроллера CarsController с одним параметром (Id), потребуется следующий код и разметка:

1 ... 612 613 614 615 616 617 618 619 620 ... 642
Перейти на страницу:
Отывы о книге
Открыть боковую панель
Комментарии
Jonna
Jonna 02.01.2025 - 01:03
Страстно🔥 очень страстно
Ксения
Ксения 20.12.2024 - 00:16
Через чур правильный герой. Поэтому и остался один
Настя
Настя 08.12.2024 - 03:18
Прочла с удовольствием. Необычный сюжет с замечательной концовкой
Марина
Марина 08.12.2024 - 02:13
Не могу понять, где продолжение... Очень интересная история, хочется прочесть далее
Мприна
Мприна 08.12.2024 - 01:05
Эх, а где же продолжение?