如何通过C#返回JSON并在JavaScript中解析它?

问题描述:

我正在使用从我的活动目录获取数据并将对象数组返回给我的JavaScript的Web服务。问题是我封装对象与_type的响应包括当我只是想返回对象的值,这样如何通过C#返回JSON并在JavaScript中解析它?

([{ value: "one", label: "Foo" }, { value: "two", label: "Bar" }]). 

但我收到此

[Object { __type="Service+NameDTO", value: "one", label: "Foo"}, Object { __type="Service+NameDTO", value:  "two", label: "Bar"}] 

这里是我的C#

public NameDTO[] GetCompletionList(string prefix) 
{ 
    var nameList = new List<NameDTO>(); 
    DirectorySearcher search = new DirectorySearcher(); 
    string strPath = search.SearchRoot.Path; 
    DirectoryEntry entry = new DirectoryEntry(strPath); 
    search.PageSize = 1000; 
    search.Filter = "(&(objectClass=user)(objectCategory=person)(displayName=*" + prefix + "*))"; 
    foreach (SearchResult sResultSet in search.FindAll()) 
    { 
     if (sResultSet.Properties["mail"].Count > 0) 
     { 
      var dto = new NameDTO() 
      { 
       label = (string)sResultSet.Properties["displayName"][0], 
       value = (string)sResultSet.Properties["mail"][0], 
      }; 
      nameList.Add(dto); 
     } 
    } 
    NameDTO[] myArray = nameList.ToArray(); 
    return myArray; 
} 
public class NameDTO 
{ 
    public string label { get; set; } 
    public string value { get; set; } 
} 

和我的javascript

<script type="text/javascript"> 
    $(document).ready(function() { 
     $('#tokenfield').tokenfield({ 
      autocomplete: { 
       source: function (request, response) { 
        $.ajax({ 
         url: '<%#ResolveUrl("~/Service1.asmx/GetCompletionList") %>', 
         data: "{ 'prefix': '" + request.term + "'}", 
         dataType: "json", 
         type: "POST", 
         contentType: "application/json; charset=utf-8", 
         success: function (data) { 
          response($.map(data.d, function (item) { 
          return data  
          })) 
         }, 
         success: function(response) { 
          $.each(response, function(key, val) { 
           alert(val.id); 
          }); 
         }, 
         error: function (response) { 
          alert(response.responseText); 
         }, 
         failure: function (response) { 
          alert(response.responseText); 
         } 
        }); 
       }, 
       search: function() { 
       var term = this.value; 
       if (term.length < 3) { 
        return false; 
       } 
       }, 
       focus: function() { 
       // prevent value inserted on focus 
       return false; 
       }, 
      }, 
     }); 
}); 
</script> 
+0

什么服务器端技术您使用的,WCF,asp.net,asp.net的MVC,网页API? –

+0

@ DanielA.White,他使用'asp.net webservice'我想。请看他的ajax网址'/ Service1.asmx/GetCompletionList' –

+0

是的asmx webservice – CameronR

您可能需要一些典型的JSON构建器。

服务器端,可以让词典,阵列等,并抛出一切都变成

JsonMapper.ToJson(jsonDict) 

电话。

这个函数在我的项目中间接调用了Newtonsoft JSON处理函数JsonSerializer()。对于序列化和反序列化JSON非常有用。

虽然我可能会误解你的问题;有点模糊。

http://weblogs.asp.net/scottgu/archive/2007/10/01/tip-trick-building-a-tojson-extension-method-using-net-3-5.aspx这里很有意思,非常有用。

它想出了,你可能需要这样:

var jsonString = @Model; //or however you get your string. 
var json = JSON.parse(jsonString); 
+0

我已经这样做了,它看起来非常接近,但它作为json的字符串传递,但我需要一个返回类型的数组。 – CameronR

+0

为什么你需要一个返回类型的数组?你回来什么_TO_? – statue

+0

我使用的jquery插件接受格式为[{value:“one”,label:“Foo”},{value:“two”,label:“Bar”}]]的对象数组) – CameronR