您的位置:首页 > 其它

关于重用PartialView以及View层次

2012-02-24 23:12 387 查看

自带数据控件@html.Action/PartialView(model)/@html.Partial


在默认访问页面中有如下代码:利用ChildActionOnly以及PartialView显示类似自带数据用户控件的作用

<div class="clear">

</div>

@Html.Action("HomePageNews","News")

<div class="clear">

</div>

@Html.Action("HomePagePolls","Poll")

-   - - - --

[ChildActionOnly]

public ActionResultHomePagePolls()

{

var polls =_pollService.GetPolls(_workContext.WorkingLanguage.Id, true,0, int.MaxValue);

// IPagedList<Poll>GetPolls(int languageId, bool loadShownOnHomePageOnly,

int pageIndex, int pageSize, boolshowHidden = false);

//只显示在Homepage,默认showHidden=false//

var model = polls.Select(x =>PreparePollModel(x)).ToList();

////内部的函数,处理Poll到PollModel的,把IpagedList<Poll>--IPagedList<PollModel>

protected PollModelPreparePollModel(Poll poll)

//

returnPartialView(model);- -- -- --- ---HomepagePolls对应HomepagePools.cshtml

}

parialView的render如下:

@model IList<PollModel>

@using Nop.Web.Framework;

@using Nop.Web.Models.Polls;

@if (Model.Count > 0)

{<div class="todays-poll-box">

<div class="todays-poll-box-block">

@foreach(var poll inModel)

{

@Html.Partial("_Poll", poll) //又继续使用了Control Template  _Poll

}

</div>

</div>

}


_Pool.cshtml的内容,从中可以看到@Html.Partial(“_Poll”,poll)这个方式不需要Controller Action的,适合最简的Control template展示。Html.Action("HomePageNews","News")是要经过Controller的。

@model PollModel

@using Nop.Web.Framework;

@using Nop.Web.Models.Polls;

<div class="poll-item">

<span class="poll-display-text">@Model.Name</span>

@if(Model.AlreadyVoted)

{ …

@Html.Raw(addToCartWarningsSb.ToString())è直接输出后台变量

@Html.Action("HomePageNews","News")->Actioni(HomepageNews)->View(Action对应的View)->Partialview(subdata)->partialview(withoutAction)-Partialview(without Action)。。。。

从逻辑假设来看,模版View可以无穷细化下去.

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: