Asp.net MVC jquery-ajax不渲染html

时间:2010-03-16 11:09:15

标签: asp.net-mvc jquery

我正在尝试使用jQuery ajax和MVC我可以让它回发到我想要的动作,它返回带有更新数据的ViewData对象,但从不渲染HTML。我有一个视图,其中包含一些MVC用户控件,我希望它们在计时器上更新。

这是我的查看标记

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/PageWithSummaryViewAndTabs.Master" Inherits="System.Web.Mvc.ViewPage" %>
<asp:Content ID="FullCaseTitle" ContentPlaceHolderID="TitleContent" runat="server">

</asp:Content>

<asp:Content ID="FullCaseContent" ContentPlaceHolderID="MainContent" runat="server">
<script type="text/javascript">
window.setInterval(test, 5000);
function test() {
    jQuery.get("/PatientCase/RefreshEPRF", function(response) { });
}
</script>

<div id="loadingDiv" style="display:none">Updating</div>

   <input id="refreshPatientCaseIndexButton" type="submit" visible="true" title="refresh" value="Refresh" />
    <h2>Full Case</h2>
    <div id="EPRFContent"> 
        <%Html.RenderPartial(@"~/Views/PatientCase/SectionEPRF.ascx"); %>
        <%Html.RenderPartial(@"~/Views/PatientCase/SectionDrugs.ascx"); %>
    </div>
    <div id="ImageContent"> 
        <%Html.RenderPartial(@"~/Views/PatientCase/SectionImagery.ascx"); %>
    </div>
</asp:Content>

在回发时,我调用一个名为RefreshEPRF的动作,它再次加载所需的用户控件

<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<%Html.RenderPartial(@"~/Views/PatientCase/SectionEPRF.ascx"); %>
<%Html.RenderPartial(@"~/Views/PatientCase/SectionDrugs.ascx"); %>

最终控制中的marpup

<table id="detailstable">
    <tr><td id="detailslablecolumn">Patient Name : </td><td>
    <%
    foreach (var item in (List<STS_Lite.Models.PatinetCase.EPRFItem>)ViewData["EPRF"])
    {
        if (item.datumItemId == 46)
        {
            if (item.Stroke)
            {
            %>
                <img src="/PatientCaseIndex/InkImageData/GetInkImage/<%=ViewData["PatientCaseId"]%>/<%=ViewData["TemplateInstanceId"]%>/<%=item.TemplateItemId %>" />
            <%
            }
            else
            {%>
                <%=item.Value.ToString()%>
            <%} 
            break;
        }
    } 
%></td></tr><table>

当我单步执行此代码时,用户控件中的ViewData具有新的更新值,但页面返回时没有新值。我尝试过jQuery.get和ajax,但没有运气。 任何帮助都会非常感谢

1 个答案:

答案 0 :(得分:1)

您必须写下您的回复...尝试这样做:

    jQuery.get("/PatientCase/RefreshEPRF", function(response) { 
        $("#EPRFContent").html(response) }); 

响应参数应该包含您的视图,并且只需将其内容放入div中即可。

您的操作调用RefreshEPRF应返回部分视图