在ASP。NET MVC,有什么区别:

超文本标记语言Partial和Html。RenderPartial方法 超文本标记语言动作和Html。RenderAction


当前回答

对于“partial”,我总是这样使用:

如果有一些东西你需要包含在一个页面,你需要通过控制器(就像你会用Ajax调用),然后使用“Html.RenderPartial”。

如果你有一个“静态”包含,它本身没有链接到控制器,而只是在“共享”文件夹中,例如,使用“HTML.partial”

其他回答

超文本标记语言Partial返回一个字符串。超文本标记语言RenderPartial内部调用Write并返回void。

基本用法是:

// Razor syntax
@Html.Partial("ViewName")
@{ Html.RenderPartial("ViewName");  }

// WebView syntax
<%: Html.Partial("ViewName") %>
<% Html.RenderPartial("ViewName"); %>

在上面的代码片段中,两个调用将产生相同的结果。

而一个可以存储Html的输出。在变量中使用Partial或从方法中返回,不能使用Html.RenderPartial。

在执行/计算期间,结果将被写入Response流。

这也适用于Html。Action和Html.RenderAction。

关于这个问题:

当Html.RenderPartial()只调用部分的名称时 看来,ASP。NET MVC将传递给部分视图相同的模型和 调用视图模板使用的ViewData字典对象。

“NerdDinner”来自专业ASP。Net MVC 1.0

Partial或RenderPartial:不需要创建动作方法。当要在局部视图上显示的数据已经存在于当前页面的模型中时使用。

Action或RenderAction:需要子动作方法。当数据显示在视图上具有独立模型时使用。

@Html。Partial和@Html。当你的Partial视图模型与父模型对应时,RenderPartial被使用,我们不需要创建任何动作方法来调用它。

@Html。Action和@Html。当你的局部视图模型独立于父模型时使用RenderAction,基本上当你想在页面上显示任何小部件类型的内容时使用。您必须创建一个action方法,该方法在从视图调用该方法时返回部分视图结果。

@Html。Partial以html编码的字符串返回视图,并使用相同的视图TextWriter对象。 @Html。这个方法返回void。 @Html。RenderPartial比@Html快。部分

PartialView的语法:

 [HttpGet] 
 public ActionResult AnyActionMethod
 {
     return PartialView();
 }