关于重用PartialView以及View层次

本文深入解析NopCommerce中利用Action、PartialView和ChildActionOnly实现的用户控件功能,详细解释如何通过这些技术优化页面结构与内容呈现,包括自带数据控件的使用、自定义模板的展示逻辑以及View层次的组织。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于重用PartialView以及View层次

分类: Nop Commerce   8人阅读  评论(0)  收藏  举报

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

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

[html]  view plain copy
  1. <div class="clear">  
  2.   
  3. </div>  
  4.   
  5. @Html.Action("HomePageNews","News")  
  6.   
  7. <div class="clear">  
  8.   
  9. </div>  
  10.   
  11. @Html.Action("HomePagePolls","Poll")  
  12.   
  13.    
  14.   
  15. -   - - - --  
  16.   
  17.  [ChildActionOnly]  
  18.   
  19.         public ActionResultHomePagePolls()  
  20.   
  21.         {  
  22.   
  23.             var polls =_pollService.GetPolls(_workContext.WorkingLanguage.Id, true,0, int.MaxValue);  
  24.   
  25. // IPagedList<Poll>GetPolls(int languageId, bool loadShownOnHomePageOnly,  
  26.   
  27.              int pageIndex, int pageSize, boolshowHidden = false);  
  28.   
  29. //只显示在Homepage,默认showHidden=false//  
  30.   
  31.             var model = polls.Select(x =>PreparePollModel(x)).ToList();  
  32.   
  33. ////内部的函数,处理Poll到PollModel的,把IpagedList<Poll>--IPagedList<PollModel>  
  34.   
  35.         protected PollModelPreparePollModel(Poll poll)  
  36.   
  37. //  
  38.   
  39.             returnPartialView(model);- -- -- --- ---HomepagePolls对应HomepagePools.cshtml  
  40.   
  41.         }  
  42.   
  43. parialView的render如下:  
  44.   
  45. @model IList<PollModel>  
  46.   
  47. @using Nop.Web.Framework;  
  48.   
  49. @using Nop.Web.Models.Polls;  
  50.   
  51. @if (Model.Count > 0)  
  52.   
  53. {<div class="todays-poll-box">  
  54.   
  55.     <div class="todays-poll-box-block">  
  56.   
  57.         @foreach(var poll inModel)  
  58.   
  59.         {   
  60.   
  61.             @Html.Partial("_Poll", poll) //又继续使用了Control Template  _Poll  
  62.   
  63.         }  
  64.   
  65.     </div>  
  66.   
  67.     </div>  
  68.   
  69. }  


 

 

_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可以无穷细化下去.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值