ASP.NET MVC視圖尋址

一、為什麼要使用視圖

使用視圖以後有兩個優點:

1、保證頁面內容輸出和控制器代碼的分離。和Code Behind不同,CodeBehind實現的是物理分離,視圖可以實現邏輯上的分離。

2、更方便、更直觀的輸出頁面內容的方式。頁面上面的邏輯可以很方便的借助Razor語法和HTML混合的方式完成,不像以前的WebFrom需要後端把所有的HTML整合好在進行輸出,這樣後臺和前端想結合起來很困難。

二、視圖的尋址

1、視圖尋址方法1

當使用View方法返回視圖的時候,是怎麼知道要執行哪個視圖頁面呢?通常的做法就是通過視圖的方法傳遞視圖的完整路徑,或者指定視圖的名稱,指定視圖路徑很好理解!如下面的代碼所示:

public ActionResult Index()
{
      return View();
}

默認情況下,啟動的時候會打開Index視圖,將代碼修改如下:

public ActionResult Index()
{
      // 指定視圖的路徑
      return View("~/Views/Home/About.cshtml");
}

運行結果:

從運行結果中可以看出,如果指定瞭視圖的路徑,那麼運行的時候打開的就會是指定路徑的視圖。

那麼指定視圖名稱(默認代碼就是使用的指定視圖名稱的方法)的時候是如何知道視圖放在什麼地方呢?難道要遍歷整個網站的路徑嗎?當然不會是這樣的,如下圖所示,它有一個尋址范圍的。

指定視圖名稱尋找視圖的步驟:

1、首先查找相應的Controller名稱對應的視圖文件夾,如果找不到,在查找Shared文件夾。

2、先查找cshtml文件。

3、這是一種約定的規則。

2、視圖尋址方法2

三、編寫視圖

前面已經接觸瞭視圖的編寫,從原理上講ASP.NET針對請求的處理最終體現在對目標Action方法的執行,並就處理的結果對請求予以響應,而ActionResult為我們提供瞭一種響應請求的快捷方式。ASP.NET MVC定義瞭一系列原生的ActionResult類型,如:EmptyResult、ContentResult等,它們或者幫助我們將指定的內容按照相應的媒體類型響應給客戶端,或者回復一個指定狀態碼的響應,又或者是實現客戶端的重定向。

ViewResult是重要也是最為常用的ActionResult,我們可以利用它將指定的View呈現在客戶端的瀏覽器上。針對ViewResult的View呈現最終是利用View引擎來實現的。View引擎中的View實現瞭IView接口,對應著某個View文件,而核心組件ViewEngine實現針對View的獲取、激活、呈現以及最終的釋放。

View文件最終編譯生成的WebViewPage<TModel>是System.Web.Mvc.WebViewPage的子類,而後者繼承自WebPageBase。我們在定義View的時侯使用的三個幫助對象(HtmlHelper、UrlHelper和AjaxHelper)所對應的屬性就定義在這裡,他們通過InitHelpers方法進行初始化。

我們在定義View的時侯可以通過隻讀屬性Model、ViewData、ViewBag和TempData得到在Controller中設置的狀態數據,也可以通過調用SetViewData設置ViewData,ViewContext表示View當前上下文。如下圖所示:

四、HTML輔助方法

下圖中列出瞭一些常見的HTML輔助方法:

 到此這篇關於ASP.NET MVC視圖尋址的文章就介紹到這瞭。希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。

推薦閱讀: