我开发了一个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);
}
谢谢,阿里
答案 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();
}