在ASP。NET MVC,有什么区别:
超文本标记语言Partial和Html。RenderPartial方法 超文本标记语言动作和Html。RenderAction
在ASP。NET MVC,有什么区别:
超文本标记语言Partial和Html。RenderPartial方法 超文本标记语言动作和Html。RenderAction
当前回答
区别是第一个返回MvcHtmlString,但第二个(Render..)直接输出到响应。
其他回答
@Html。Partial以html编码的字符串返回视图,并使用相同的视图TextWriter对象。 @Html。这个方法返回void。 @Html。RenderPartial比@Html快。部分
PartialView的语法:
[HttpGet]
public ActionResult AnyActionMethod
{
return PartialView();
}
区别是第一个返回MvcHtmlString,但第二个(Render..)直接输出到响应。
以下是我的发现:
使用RenderAction当你没有一个模型发送到视图,有很多html带回,不需要存储在一个变量。
当你没有要发送到视图的模型,并且有一些需要存储在变量中的文本要返回时,请使用Action。
使用RenderPartial当你有一个模型发送到视图,将有很多html,不需要存储在一个变量。
当你有一个模型要发送到视图,并且有一些文本需要存储在一个变量中时,使用Partial。
RenderAction和RenderPartial更快。
对于“partial”,我总是这样使用:
如果有一些东西你需要包含在一个页面,你需要通过控制器(就像你会用Ajax调用),然后使用“Html.RenderPartial”。
如果你有一个“静态”包含,它本身没有链接到控制器,而只是在“共享”文件夹中,例如,使用“HTML.partial”
@Html。Partial和@Html。当你的Partial视图模型与父模型对应时,RenderPartial被使用,我们不需要创建任何动作方法来调用它。
@Html。Action和@Html。当你的局部视图模型独立于父模型时使用RenderAction,基本上当你想在页面上显示任何小部件类型的内容时使用。您必须创建一个action方法,该方法在从视图调用该方法时返回部分视图结果。