中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ASP.NET MVC 視圖(四)

發布時間:2020-07-17 08:38:19 來源:網絡 閱讀:758 作者:jinyuan0829 欄目:編程語言

ASP.NET MVC 視圖()

前言

上篇對于利用IoC框架對視圖的實現進行依賴注入,最后還簡單的介紹一下自定義的視圖輔助器是怎么定義和使用的,對于Razor語法的細節和輔助器的使用下篇會說講到,本篇來講解一下視圖中的分段概念、和分部視圖的使用。

ASP.NETMVC 視圖

l  自定義視圖引擎

l Razor視圖引擎執行過程

l  Razor視圖的依賴注入、自定義視圖輔助器

l  分段、分部視圖的使用

l Razor語法、視圖輔助器

 

分段、分部視圖的使用

分段的使用

ASP.NET MVC框架的Razor引擎中有著分段的概念,分段什么意思呢?分段的意思就是把視圖分成幾個自定義的分段,并且交由布局來控制分段的顯示。說是這么說,我們還是來看一看代碼的定義,首先是使用了分段的視圖代碼的定義,示例代碼1-1.

代碼1-1

@{
    ViewBag.Title = "ViewPartCase";
}
 
<h3>ViewPartCase</h3>
 
@section PartOne
{
<h2>這是使用分段的示例:分段一</h2>
}
 
@section PartTwo
{
<h2>這是使用分段的示例:分段二</h2>
}
 
@section PartThree
{
<h2>這是使用分段的示例:分段三</h2>
}


在代碼1-1中,使用@section標間來創建分段,而后面緊跟著的就是自定義分段的名稱,這個時候布局的代碼如示例代碼1-2.

代碼1-2

<!DOCTYPE html>
<html>
<head>
    <title>@ViewBag.Title</title>
    <link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
    <script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
</head>
 
<body>
    @RenderBody()
</body>
 
</html>


這個時候的運行結果如圖1

1

ASP.NET MVC 視圖(四)

很明顯的看到圖1中所提示的錯誤信息,在布局中并未定義PartOnePartTowPartThree

這樣我們只能修改代碼1-2,修改布局中的定義,修改后的示例代碼1-3.

代碼1-3

<!DOCTYPE html>
<html>
<head>
    <title>@ViewBag.Title</title>
    <link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
    <script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
</head>
 
@RenderSection("PartOne")
@RenderSection("PartThree")
 
<body>
    @RenderBody()
</body>
@RenderSection("PartTwo")
</html>


在代碼1-3@RenderSection標簽用于顯示指定的分段,參數為自定義的分段名稱,這里大家要清楚一個概念,就是布局的定義是來引導視圖分段的定義,只不過在本篇幅是為了讓大家清楚的理解所以顛倒了順序,實際運用中應該是先定義好布局中所要使用的分段,以及指示的分段名稱,然后在視圖的定義中如果要使用當前的布局則會根據當前布局中的指定的分段名稱來定義內容。看下以上代碼運行結果如圖2.

2

ASP.NET MVC 視圖(四)

比如說現在我是先定義好的代碼1-3,然后要我定義我要呈現的頁面也就是我們的視圖,像代碼1-1那樣定義就是正常的應用順序,那我現在修改代碼1-1,因為我不想我的視圖中使用分段,示例代碼1-4

代碼1-4

@{
    ViewBag.Title = "ViewPartCase";
}
 
<h3>ViewPartCase</h3>


正如大家所看到的,代碼1-4也就是我修改后的視圖,就是顯示一個標題,不想有其他的東西,再次運行結果如圖2.

3

ASP.NET MVC 視圖(四)

3中明確的指示出了視圖中并未定義名為PartOne的分段,所以才會導致這樣的錯誤,就算定義了PartOne,到了PartThree還要定義,不然接著報錯,這就是強制約束了,這樣多不人道主義阿對吧。

面對這樣的情況,我們有兩種方式來處理這種情況,

第一種,使用IsSectionDefinde()方法,方法參數即為分段名稱,以此判斷視圖中是否定義了此名稱的分段,如果定義了則會返回true,否則返回false(下面代碼會給出示例)。

第二種,使用@RenderSection()方法的重載版本,講第二個參數設置為false,如果視圖中包含了方法參數所指定的分段則會顯示,沒有則不會報出異常。

現在我們來看一下,修改布局代碼1-3中的代碼以此演示上面說到的兩種情況,示例代碼1-5.

代碼1-5

<!DOCTYPE html>
<html>
<head>
    <title>@ViewBag.Title</title>
    <link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
    <script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
</head>
@if (IsSectionDefined("PartOne"))
{
    @RenderSection("PartOne")
}
@RenderSection("PartThree",false)
<body>
    @RenderBody()
</body>
@RenderSection("PartTwo",false)
</html>


這個時候我們再來看一下結果圖4,

4

ASP.NET MVC 視圖(四)

 

分部視圖的使用

對于分部視圖的使用其實也就是跟視圖一樣的,但是分布視圖跟視圖的區別在于分部視圖是禁用布局的,也就是說上面小節所說的分段在分部視圖中使用是毫無意義的,下面我們就來看一下分部視圖的定義

5

ASP.NET MVC 視圖(四)

5中并沒有創建強類型的分部視圖,這樣做的意義不大,在點擊“添加”按鈕后,所呈現的代碼頁面是個空的頁面什么都沒有,這里主要是給大家看一下分部視圖在編譯后類型所呈現的樣子也就是跟普通的視圖沒什么區別,示例代碼1-6.

代碼1-6

   

 public class _Page_Views_iocdemo_CustomPartialView_cshtml: System.Web.Mvc.WebViewPage<dynamic> {
        
#line hidden
 
        
        public_Page_Views_iocdemo_CustomPartialView_cshtml() {
        }
        
        protectedASP.global_asax ApplicationInstance {
            get{
                return((ASP.global_asax)(Context.ApplicationInstance));
            }
        }
        
        public override voidExecute() {
WriteLiteral("<h2>PartialView</h2>");
 
 
        }
    }


代碼1-6所呈現的就如同在ASP.NET MVC 視圖()中最后所示的示例那般,核心的地方是不會變的,我們還是來刪除掉這個分部視圖,重新添加一個同樣命名的強類型視圖,或者直接使用@model標簽來引用一個類型作為視圖的Model類型,示例代碼1-7.

代碼1-7

@model MvcApplication.Models.CustomerInfo
 
<h2>@Model.ID</h2>
<h3>@Model.Name</h3>

我們再看一下對于分部視圖使用的視圖的代碼定義,示例代碼1-8

代碼1-8

@model IEnumerable<MvcApplication.Models.CustomerInfo>
@{
    ViewBag.Title = "ViewPartCase";
}
<h3>
    ViewPartCase</h3>
@foreach (varmodel in Model)
{
    @Html.Partial("CustomPartialView",model)
}

最后的呈現的界面如圖6.

6

ASP.NET MVC 視圖(四)


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

常宁市| 宁明县| 加查县| 吴桥县| 五家渠市| 林甸县| 蒲江县| 郴州市| 高阳县| 毕节市| 昌平区| 金寨县| 汶川县| 交口县| 广德县| 枝江市| 资源县| 同仁县| 灵寿县| 灵丘县| 洪泽县| 萝北县| 兰西县| 武清区| 九龙城区| 佛坪县| 高州市| 鹿邑县| 莲花县| 新郑市| 应城市| 丽水市| 西和县| 清新县| 郎溪县| 霍城县| 石门县| 山阳县| 盐山县| 临颍县| 岫岩|