我需要做更多的决定性调查,但是为了防止有人遇到类似的问题或更多的见解,这里是我到目前为止。首先,我应该说,所有的结果和测量都是在多页加载之后完成的,而且我设置了< compilation debug =“false”>在我的web.config
>似乎单个渲染部分引起约5ms的打击(至少在我的环境中)。当我内联部分视图的实际内容时,几乎达到了0ms。
>当我将一个空的部分视图包含在大约70个元素的循环中时,总渲染时间增加大约60ms。所以有可能有一些缓存,但它并不理想。
>我调试了ASP.NET MVC,并发现部分视图被缓存,但它只缓存了ascx的路径。然后每次使用BuildManager.CreateInstanceFromVirtualPath方法实例化实际视图。
>现在有趣的是:当使用WebForms语法(< my:UserContol runat =“server”/>)包含相同的部分视图时,额外的60ms消失。
所以基于上述观察,似乎是BuildManager.CreateInstanceFromVirtualPath方法的罪魁祸首。也许,这不是多次被称为。 Webforms可能不会使用它;或者以某种方式使用它每个ascx只有一次?
解决方法
<table> foreach(var a in items) { <%: Html.Partial("SomePartialView",a) %> } </table>
SomePartialView包含用于在表中呈现单行的代码,例如:
<tr><td>Model.Name</td><td>Model.description</td></tr>
至 :
foreach(var a in items) { <tr><td>a.Name</td><td>a.description</td></tr> }
对于渲染900行的视图,页面渲染时间从5分钟页面加载下降到不到30秒,非常确凿的证明,在调用部分视图时有一个重大的开销。我确定这是可以忽略的,当你有一个单一的呼叫,但是在一个循环中,它都加起来,所以我建议避免在循环中的部分视图,如果可能的话。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。