我的asp.net网站上的ajax错误

时间:2011-12-12 06:03:44

标签: c# jquery asp.net ajax flexigrid

我开发了一个asp.net site.in大多数页面,我在cliend站点使用$.ajax method jquery库,在服务器端使用web方法。

当我在本地计算机上运行我的网站时,它是正确的,但当我在我的主机上上传时,大多数ajax请求都会出错。

这是一个例子:

EX:我有一个flexi网格,并希望在文档准备就绪时将数据加载到其中,但是错误已经发生并且我被firebug捕获了:

The method 'FetchCountryList' returns a value of type 'System.Xml.XmlDocument', which
cannot be serialized as Xml. Original error: Unable to generate a temporary class 
(result=1). error CS2001: Source file 'C:\WINDOWS\TEMP\d2h0eyni.0.cs' could not be 
found error CS2008: No inputs specified 

我想帮助解决此错误

这是我在客户端的代码:

               $("#GrdCountry").flexigrid({
                    url: 'CountryDefinition.aspx/FetchCountryList',
                    dataType: 'xml',
                    colModel: [
                        { display: 'Name', name: 'Name', width: 210, sortable: true, align: 'left' },
                        { display: 'Code', name: 'Code', width: 100, sortable: true, align: 'left' },
                        { display: 'Capital', name: 'Capital', width: 210, sortable: true, align: 'left' },
                        { display: 'Actions', width: 100, align: 'Center'}],
                    buttons: [
                        { name: 'Add', bclass: 'add', onpress: addOpr },
                        { separator: true}],
                    searchitems: [
                        { display: 'Name', name: 'Name', isdefault: true },
                        { display: 'Capital', name: 'Capital'}],
                    sortname: "Name",
                    sortorder: "asc",
                    usepager: true,
                    //title: 'Countries',
                    useRp: true,
                    rp: 10,
                    resizable: false,
                    showTableToggleBtn: false,
                    width: 783,
                    height: 330
                });

这是我在服务器端的代码:

[WebMethod]
    [ScriptMethod(ResponseFormat = ResponseFormat.Xml)]
    public static XmlDocument FetchCountryList(int page, int rp, string sortname, string sortorder, string query, string qtype)
    {
        CountryBL CountryBLO = new CountryBL();
        XDocument xmlDoc = new XDocument(
            new XDeclaration("1.0", "utf-8", "yes"),

                new XElement("rows",
                    new XElement("page", page.ToString()),
                    new XElement("total", CountryBLO.Load().Count.ToString()),
                    CountryBLO.Load(page, rp, sortname, sortorder, query, qtype).Select(row => new XElement("row", new XAttribute("Id", row.Id.ToString()),
                                                      new XElement("cell", row.Name.ToString()),
                                                      new XElement("cell", row.Code.ToString()),
                                                      new XElement("cell", row.Capital.ToString()),
                                                      new XElement("cell", "<img id='imgEdit' lang='" + row.Id.ToString() + @"' style='cursor:pointer;border:0px;' src='../../Storage/Images/FlexGrid/edit.png' />
                                                                            <img id='imgDelete' lang='" + row.Id.ToString() + "' style='cursor:pointer;border:0px;' src='../../Storage/Images/FlexGrid/delete.gif' />")                        
                                                    )
                                )
                    )
        );
        return Tools.XDocumentToXmlDocument(xmlDoc);
    }

谢谢,阿里

1 个答案:

答案 0 :(得分:2)

尝试返回String。

[WebMethod]
    [ScriptMethod(ResponseFormat = ResponseFormat.Xml)]
    public static String FetchCountryList(int page, int rp, string sortname, string sortorder, string query, string qtype)
    {
        CountryBL CountryBLO = new CountryBL();
        XDocument xmlDoc = new XDocument(
            new XDeclaration("1.0", "utf-8", "yes"),

                new XElement("rows",
                    new XElement("page", page.ToString()),
                    new XElement("total", CountryBLO.Load().Count.ToString()),
                    CountryBLO.Load(page, rp, sortname, sortorder, query, qtype).Select(row => new XElement("row", new XAttribute("Id", row.Id.ToString()),
                                                      new XElement("cell", row.Name.ToString()),
                                                      new XElement("cell", row.Code.ToString()),
                                                      new XElement("cell", row.Capital.ToString()),
                                                      new XElement("cell", "<img id='imgEdit' lang='" + row.Id.ToString() + @"' style='cursor:pointer;border:0px;' src='../../Storage/Images/FlexGrid/edit.png' />
                                                                            <img id='imgDelete' lang='" + row.Id.ToString() + "' style='cursor:pointer;border:0px;' src='../../Storage/Images/FlexGrid/delete.gif' />")                        
                                                    )
                                )
                    )
        );

StringBuilder builder = new StringBuilder();
        using (TextWriter writer = new StringWriter(builder))
        {
            doc.Save(writer);
        }

        return builder.ToString();
    }