這篇文章主要為大家展示了“MVC頁面之間參數(shù)傳遞如何實(shí)現(xiàn)”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“MVC頁面之間參數(shù)傳遞如何實(shí)現(xiàn)”這篇文章吧。
成都創(chuàng)新互聯(lián)公司專注于網(wǎng)站建設(shè)|成都企業(yè)網(wǎng)站維護(hù)|優(yōu)化|托管以及網(wǎng)絡(luò)推廣,積累了大量的網(wǎng)站設(shè)計(jì)與制作經(jīng)驗(yàn),為許多企業(yè)提供了網(wǎng)站定制設(shè)計(jì)服務(wù),案例作品覆蓋成都門窗定制等行業(yè)。能根據(jù)企業(yè)所處的行業(yè)與銷售的產(chǎn)品,結(jié)合品牌形象的塑造,量身制作品質(zhì)網(wǎng)站。
一、Html.RenderAction 方式頁面之間傳遞參數(shù)的方式:
Html.RenderAction 方式 是訪問的另一頁面的Controller,并將參數(shù)傳入另一頁面的Controller中相應(yīng)的Action中的參數(shù)中。
例如:我有這么一個(gè)Controller和Action(是一個(gè)部分視圖的)
public class TopController : Controller { // GET: Top public ActionResult Index(string content) { ViewBag.content = content; return PartialView(); } }
這個(gè)Index中,將接到的參數(shù)寫到ViewBag.content中,一面前端View界面中取到。如下:
那么我們?nèi)绾卫肏tml.RenderAction方式,將參數(shù)傳入到這個(gè)頁面然后展示出來呢?
這就是利用Html.RenderAction方式,傳遞參數(shù)給Top 中的 Index 頁的。
二、Html.RenderPartial 方式
Html.RenderPartial 方式 與 Html.RenderAction 不同,他沒有將參數(shù)傳遞到另一頁面的Controller對應(yīng)的Action,而是直接傳遞到另一界面的Model中。
所以,Html.RenderAction傳值不會經(jīng)過Controller直接進(jìn)入Model。
下面我們來看一下具體的操作。
1、首先我們簡歷一個(gè)簡單的Model模型。
public class Person { public string Name { get; set; } public string Sex { get; set; } }
2、建立界面Boot頁,(Boot自己取的名字) 其 View如下:
上面代碼中,我們將頁面的model制定未Person類。在兩個(gè)
建立完這個(gè)頁面,我們就要向這個(gè)頁面?zhèn)髦盗耍敲慈绾斡?Html.RenderPartial 向其中傳值呢? 如下:
上述紅框中即為用 Html.RenderPartial 方式傳值。
這種方式似乎還有不足的地方,是的,我們不可能每次用Html.RenderPartial方式傳值的時(shí)候,都要去建立一個(gè)Model模型,這樣的話幾乎是場災(zāi)難。那么如何避免呢?
我們用Html.RenderPartial方式向另一界面?zhèn)髦档睦硐敕绞交蛟S是這樣的:
如上面紅框中所示。直接用一個(gè)匿名對象將參數(shù)包進(jìn)去,然后傳遞過去就行,但是,另一個(gè)頁面是否會接受到呢?
或許,大家早已經(jīng)測試過了,答案是:不可以。在Model中去Name和Sex,會報(bào)錯(cuò)的(相信各位園友們早已實(shí)驗(yàn)過了)
那么我們?nèi)绾胃倪M(jìn),能讓這個(gè)頁面可以接受到這種方式的參數(shù)傳遞呢?如下:
上述方式去取值,就會取到傳遞過來的匿名對象的相應(yīng)屬性了。是不是很high啊,以后傳值就方便多了。
傳遞的參數(shù)的類型也可以是多種多樣,例如:
我們加了一個(gè)DateTime類型的參數(shù),那么另一界面還是一樣,照接不誤。
頁面
以上是“MVC頁面之間參數(shù)傳遞如何實(shí)現(xiàn)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!