首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何从ViewEngineResult获取呈现的PartialView

从ViewEngineResult获取呈现的PartialView可以通过以下步骤实现:

  1. 首先,需要在控制器中调用View方法来获取ViewEngineResult对象。例如:
代码语言:txt
复制
ViewEngineResult result = View("PartialViewName");

这将返回一个ViewEngineResult对象,其中包含了呈现的PartialView的相关信息。

  1. 接下来,可以通过检查ViewEngineResult对象的View属性来获取呈现的PartialView。例如:
代码语言:txt
复制
var partialView = result.View;

这将返回一个IView对象,表示呈现的PartialView。

  1. 如果需要将PartialView呈现为字符串,可以使用ViewEngineResult对象的FindView方法。例如:
代码语言:txt
复制
var viewContext = new ViewContext();
var viewData = new ViewDataDictionary(viewContext, new EmptyModelMetadataProvider());
var tempData = new TempDataDictionary(viewContext, new SessionStateTempDataProvider());

using (var writer = new StringWriter())
{
    var viewResult = result.View.RenderAsync(new ViewContext(viewContext, result.View, viewData, tempData, writer, new HtmlHelperOptions()));
    viewResult.GetAwaiter().GetResult();
    var renderedPartialView = writer.GetStringBuilder().ToString();
}

这将使用ViewEngineResult对象的View属性呈现PartialView,并将结果存储在renderedPartialView变量中。

总结: 从ViewEngineResult对象获取呈现的PartialView可以通过调用View方法并检查返回的ViewEngineResult对象的属性来实现。然后,可以使用RenderAsync方法将PartialView呈现为字符串。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • select2 api参数的文档

    // 加载数据 $("#e11").select2({ placeholder: "Select report type", allowClear: true, data: [{id: 0, text: 'story'},{id: 1, text: 'bug'},{id: 2, text: 'task'}] }); // 加载数组 支持多选 $("#e11_2").select2({ createSearchChoice:function(term, data) { if ($(data).filter(function() { return this.text.localeCompare(term)===0; }).length===0) {return {id:term, text:term};} }, multiple: true, data: [{id: 0, text: 'story'},{id: 1, text: 'bug'},{id: 2, text: 'task'}] }); function log(e) { var e=$("

  • "+e+"
  • "); $("#events_11").append(e); e.animate({opacity:1}, 10000, 'linear', function() { e.animate({opacity:0}, 2000, 'linear', function() {e.remove(); }); }); } // 对元素 进行事件注册 $("#e11") .on("change", function(e) { log("change "+JSON.stringify({val:e.val, added:e.added, removed:e.removed})); }) // 改变事件 .on("select2-opening", function() { log("opening"); }) // select2 打开中事件 .on("select2-open", function() { log("open"); }) // select2 打开事件 .on("select2-close", function() { log("close"); }) // select2 关闭事件 .on("select2-highlight", function(e) { log ("highlighted val="+ e.val+" choice="+ JSON.stringify(e.choice));}) // 高亮 .on("select2-selecting", function(e) { log ("selecting val="+ e.val+" choice="+ JSON.stringify(e.choice));}) // 选中事件 .on("select2-removing", function(e) { log ("removing val="+ e.val+" choice="+ JSON.stringify(e.choice));}) // 移除中事件 .on("select2-removed", function(e) { log ("removed val="+ e.val+" choice="+ JSON.stringify(e.choice));}) // 移除完毕事件 .on("select2-loaded", function(e) { log ("loaded (data property omitted for brevity)");}) // 加载中事件 .on("select2-focus", function(e) { log ("focus");}) // 获得焦点事件 .on("select2-blur", function(e) { log ("blur");}); // 失去焦点事件 $("#e11").click(function() { $("#e11").val(["AK","CO"]).trigger("change"); }); 官网文档地址是:http://select2.github.io/select2/#documentation。说再多也没用,最后我们来个实例来证明一下ajax请求远程数据,以截图为准:

    05

    [ASP.NET MVC] 利用动态注入HTML的方式来设计复杂页面

    随着最终用户对用户体验需求的不断提高,实际上我们很多情况下已经在按照桌面应用的标准来设计Web应用,甚至很多Web页面本身就体现为一个单一的页面。对于这种复杂的页面,我们在设计的时候不可以真的将所有涉及的元素通通至于某个单独的View中,将复杂页面相对独立的内容“分而治之”才是设计之道。我们可以借鉴Smart Clent应用的设计方式:将一个Windows Form作为应用的容器(Smart Client Shell),在操作过程中动态地激活相应的用户控件(Smart Part)并加载到容器中。对于一个复杂页面来说,我们也只需要将其设计成一个容器,至于运行过程中动态显示的内容则可以通过Ajax调用获取相应的HTML来填充。[源代码从这里下载]

    02
    领券