[英]Passing parameter to WebMethod with jQuery Ajax getting error
我正在使用Web方法和Ajax调用,但无法通过参数正确地进行操作吗?
我已经做了很多修复工作,但是还不能解决我的问题?
我需要通过字符串并让我的Web方法返回数据表,为什么有必要将其作为json传递呢?
这是ajax调用:
var jsdata = '{category:' + category + '}';
var jstext = JSON.stringify(jsdata, null, 2);
$.ajax({
type: "POST",
url: "GIFacRequest.aspx/GetSubCategories",
data: jstext ,
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (dtSubCategory) {
PopulateSubCategoryDD(dtSubCategory);
},
error: function (response) {
$('body', document).html(response.responseText);
}
});
而我的网络方法:
[System.Web.Services.WebMethod()]
[System.Web.Script.Services.ScriptMethod()]
public static DataTable GetSubCategories(string category)
{
}
我得到的错误如下:
“消息”:“无法将类型\\ u0027System.String \\ u0027的对象转换为类型\\ u0027System.Collections.Generic.IDictionary`2 [System.String,System.Object] \\ u0027”,“ StackTrace”:“在System.Web .Script.Serialization.ObjectConverter.ConvertObjectToTypeInternal(Object o,Type type,JavaScriptSerializer serializer,Boolean throwOnError,Object&convertedObject)\\ r \\ n位于System.Web.Script.Serialization.ObjectConverter.ConvertObjectToTypeMain(Object o,Type type,JavaScriptSerializer序列化器,在System.Web.Script.Serialization.JavaScriptSerializer.Deserialize(JavaScriptSerializer序列化器,字符串输入,类型类型,Int32 depthLimit)处的布尔throwOnError,Object&convertObject)\\ r \\ n在System.Web.Script.Serialization.JavaScriptSerializer处。在System.Web.Script.Services.RestHandler.GetRawParamsFromPostRequest(HttpContext上下文,JavaScriptSerializer序列化器)处反序列化[T](String输入)\\ r \\ n在System.Web.Script.Services.RestHandler.GetRawParams(WebServiceMethodData methodData处) ,HttpContex t context)\\ r \\ n在System.Web.Script.Services.RestHandler.ExecuteWebServiceCall(HttpContext context,WebServiceMethodData methodData)“,” ExceptionType“:” System.InvalidOperationException“
您的变量params var jsdata = '{category:' + category + '}'
是一个字符串。
所以这行: JSON.stringify(jsdata, null, 2);
,是多余的(或者应该是)。 只需设置数据:jsdata,
尝试使用此代码
var jsdata = '{category:' + category + '}';
$.ajax({
type: "POST",
url: "GIFacRequest.aspx/GetSubCategories",
data: jsdata ,
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (dtSubCategory) {
PopulateSubCategoryDD(dtSubCategory);
},
error: function (response) {
$('body', document).html(response.responseText);
}
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.