通过jQuery加载ascx

时间:2011-01-04 18:36:59

标签: asp.net jquery webforms

有没有办法通过jQuery加载ascx文件?

更新

感谢@Emmett和@Yads。我正在使用带有以下jQuery ajax代码的处理程序:

 jQuery.ajax({
    type: "POST",  //GET
    url: "Foo.ashx",
    data: '{}',
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    success: function (response)
    {
        jQuery('#controlload').append(response.d); // or response
    },
    error: function ()
    {
        jQuery('#controlload').append('error');
    }
 });

但是我收到了错误。我的代码错了吗?

另一个更新: 我正在使用

error: function (xhr, ajaxOptions, thrownError)
{
    jQuery('#controlload').append(thrownError);
}

这就是我得到的:

  

无效的JSON:
  Test =>(此测试是我的ascx中的标签)

和错误后的我的ascx文件!!!

另一个更新

我的ascx文件是这样的:

<asp:DropDownList ID="ddl" runat="server" AutoPostBack="true">
    <asp:ListItem>1</asp:ListItem>
    <asp:ListItem>2</asp:ListItem>
</asp:DropDownList>
<asp:Label ID="Label1" runat="server">Test</asp:Label>

但是在调用ajax时我在asp ::(

  

'DropDownList'类型的控件'ctl00_ddl'必须放在带有runat = server的表单标记内。

感谢@Yads。但他的解决方案只适用于html标签。

3 个答案:

答案 0 :(得分:12)

建立艾美特的解决方案

public class FooHandler : IHttpHandler
{

    public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "text/html";
        context.Response.Write(RenderPartialToString("Foo.ascx"));
    }

    private string RenderPartialToString(string controlName)
    {
        Page page = new Page();
        Control control = page.LoadControl(controlName);
        page.Controls.Add(control);

        StringWriter writer = new StringWriter();
        HttpContext.Current.Server.Execute(page, writer, false);

        return writer.ToString();
    }

    public bool IsReusable
    {
        get
        {
            return false;
        }
    }
}

使用以下jquery请求

jQuery.ajax({
    type: "POST",  //GET
    url: "Foo.ashx",
    dataType: "html",
    success: function (response)
    {
        jQuery('#controlload').append(response); // or response
    },
    error: function ()
    {
        jQuery('#controlload').append('error');
    }
 });

答案 1 :(得分:4)

public ActionResult Foo()
{
    return new ContentResult
    {
        Content = RenderPartialToString("Foo.ascx", null),
        ContentType = "text/html"
    };
}

//http://www.klopfenstein.net/lorenz.aspx/render-partial-view-to-string-asp-net-mvc-benchmark
public static string RenderPartialToString(string controlName, ViewDataDictionary viewData)
{
    ViewPage vp = new ViewPage();

    vp.ViewData = viewData;

    Control control = vp.LoadControl(controlName);
    vp.Controls.Add(control);

    StringBuilder sb = new StringBuilder();

    using (StringWriter sw = new StringWriter(sb))
    {
        using (HtmlTextWriter tw = new HtmlTextWriter(sw))
        {
            vp.RenderControl(tw);
        }
    }

    return sb.ToString();
}

答案 2 :(得分:1)

* .ascx文件在服务器端(* .aspx页面内)呈现,而不是客户端(执行JavaScript)。

一个选项可能是创建一个空白* .aspx,将用户控件放在* .aspx页面上,然后通过jQuery获取该页面并将结果转储到页面上。

修改

根据您的评论,我有另一个建议:

如果您正在开发CMS样式应用程序,则应构建* .ascx控件,使其为compatible with the ASP.NET AJAX Toolkit。这将允许用户在不进行完全刷新的情况下向页面添加内容。

如果您真的想让用户感觉良好,那么您应该查看Web Parts and ASP.NET AJAX,因为Web部件的设计非常合适,以便用户可以自定义其页面上的内容。