2010-05-03 58 views
2

我试图使用JSON.stringify()(来自json [dot] org的json2.js)将JavaScript数组转换为JSON字符串并将其传递给asmx Web方法。我使用jQuery AJAX。将数组转换为JSON并将其传递给asmx

呼叫到达网络方法,我以列表<Object>作为参数,但我在调试模式下得到一个列表。我的JSON字符串看起来很像所有的数据,我甚至尝试过在JSON字符串的'名称'周围使用单引号和双引号(转义)。请帮忙。

回答

5
[WebMethod] 
public void SomeMethod(List<object> param) 
{ 
.... 
} 

会接受一个JSON字符串,它看起来像这样:

'{"param": ["xx", "zz", "yy"]}' 

因此,尝试这样的事情:

var data = JSON.stringify({param: myarray}); 
+0

就是这样:-)。我在做 - JSON.stringify(myArr); 但它包裹在成员'd'中。所以,这工作 - JSON.stringify(myArr.d); – user96403 2010-05-03 13:09:07

0

我已经找到了解决您的问题

解决方案prashiddha.com.np

  <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> 

      <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

      <html xmlns="http://www.w3.org/1999/xhtml"> 
      <head runat="server"> 
      <title></title> 

      <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script> 
      <script type="text/javascript"> 
       var url = '<%=ResolveUrl("~/WebService.asmx/HelloWorld")%>'; 
       $(document).ready(function() { 
        $('#txtAutoSuggest').keyup(function() { 
        var str = $("#txtAutoSuggest").val(); 
        var a = JSON.stringify({ name: str }); 
        CallService(a); 
       }); 
      }); 

      function CallService(a) { 
      $.ajax({ 
       type: "POST", 
       url: url, 
       data: a, 
       contentType: "application/json; charset=utf-8", 
       dataType: "json", 
       success: function(data, status) { 
       $('#lblResult').text(data.d); 
      }, 
      error: Error 
      }); 
      } 

      function Error(request, status, error) { 
       $('#lblResult').text("Not Matched"); 
      } 
      </script> 
      </head> 
      <body> 
      <form id="form1" runat="server"> 
      <div> 
      <asp:TextBox ID="txtAutoSuggest" runat="server"></asp:TextBox> 
      <asp:Label ID="lblResult" Text=" " Width="100%" runat="server" /> 
      </div> 
      </form> 
      </body> 
      </html> 
相关问题