溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在ASP.NET MVC中使用分部視圖

發(fā)布時(shí)間:2021-06-07 17:45:59 來(lái)源:億速云 閱讀:375 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

如何在ASP.NET MVC中使用分部視圖?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

什么是分部視圖,我們應(yīng)該什么時(shí)候應(yīng)該用?

作為一個(gè)對(duì)ASP.NET MVC 模型很熟悉的開(kāi)發(fā)者,他們自然想創(chuàng)建一個(gè)內(nèi)容和代碼都可以重用的組件,在web 窗體,我們可以創(chuàng)建一個(gè)web用戶控件或web服務(wù)器控件。但是在MVC,我們應(yīng)該用分部視圖,在這個(gè)概念的角度看,對(duì)任何情景的應(yīng)用情景都應(yīng)該有用。

在應(yīng)用程序中,每一頁(yè)上都顯示這個(gè)股票行情

在應(yīng)用程序中,一個(gè)日歷控件顯示在多個(gè)頁(yè)面中

一個(gè)登錄框

用于在多個(gè)頁(yè)面上的社交網(wǎng)絡(luò)組件,如Facebook的Like按鈕。

雖然ASP.NET MVC 的分部視圖,在語(yǔ)法和功能這兩個(gè)不同的角度,理論上可以理解為用戶控件。WEB用戶控件在WEB窗體中使用ViewState、PostBacks, and Events 。而在MVC的分部視圖,不使用任何上述技術(shù)管理狀態(tài)。正如ASP.NET Web用戶控件做的,分部視圖,可以挖掘到你的應(yīng)用程序以及其他應(yīng)用程序組件之間的數(shù)據(jù)共享中的模型。

1、創(chuàng)建分部視圖:

在解決方案管理器中,找到Views文件夾下的Shared文件夾,右鍵添加視圖,選擇創(chuàng)建為分部視圖,如圖:

如何在ASP.NET MVC中使用分部視圖

2、修改分部視圖:

<p>分部視圖中的p元素</p>

3,在其他視圖中引用分布視圖:

 @Html.Partial("~/Views/Shared/IncludePart.cshtml");
 <p>原視圖中的p元素</p>

效果如圖所示:

如何在ASP.NET MVC中使用分部視圖

4,第二種引用方法,代碼如下:

 @Html.Action("Test","Home")
 <p>原視圖中的p元素</p>

并且修改Home控制器中的Test動(dòng)作方法,代碼如下:

   public ActionResult Test()
   {
    return View("~/Views/Shared/IncludePart.cshtml");
   }

運(yùn)行后的效果與3中的一致。

5,可以向Action中傳遞參數(shù),代碼如下:

 @Html.Action("Test", "Home", new { name = "SharpL", id = 1 })
 <p>原視圖中的p元素</p>

修改分部視圖中的代碼為:

<p>我是分部視圖</p>
<p>博客名為:@ViewBag.name</p>
<p>博客的id為:@ViewBag.id</p>

修改Home控制器中Test動(dòng)作方法的代碼如下:

public ActionResult Test(string name,int id)
  {
   ViewBag.id = id;
   ViewBag.name = name;
   return View("~/Views/Shared/IncludePart.cshtml");
  }

運(yùn)行后的效果如圖:

如何在ASP.NET MVC中使用分部視圖

6,普通的視圖也可以作分部視圖使用

代碼如下:

@Html.Partial("~/Views/View1.cshtml")

其中View1為普通視圖如下:

 <p>我是普通視圖中的p元素</p>

效果如圖所示:

如何在ASP.NET MVC中使用分部視圖

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI