Возврат DataSet из WebService и заполнение списка данных с использованием jQuery $ .ajax - PullRequest
1 голос
/ 14 марта 2011

Есть ли способ, чтобы я мог заполнить список данных из возвращенного набора данных из веб-службы. Я хочу использовать функцию $ .ajax jquery. Если да, то, пожалуйста, приведите небольшой пример.

Ответы [ 2 ]

3 голосов
/ 17 февраля 2012

Этот вопрос довольно старый ... но я все равно отвечу.

Я бы порекомендовал использовать пользовательский класс, но можно сделать, используя DataSets.

JQuery код:

  <script type="text/javascript">
    $.ajax({
      type: "POST",
      url: "Default.aspx/GetSomeData",
      data: "{}",
      contentType: "application/json; charset=utf-8",
      dataType: "xml",
      success: function (msg) {
        $(msg).find('Table').each(function (i, row) {
          alert($(row).find('Field').text());
        });
      }
    });
  </script>

C # код:

    [WebMethod]
    [ScriptMethod(ResponseFormat = ResponseFormat.Xml)]
    public static string GetSomeData()
    {
        var dataSet = new DataSet();

        // Use proper try-catch!
        string connStr = "Connection String Here";
        using (var conn = new SqlConnection(connStr))
        {
            using (var com = new SqlCommand("select top 5 ID, Field from Table", conn))
            {
                var adp = new SqlDataAdapter(com);
                adp.Fill(dataSet);
            }
        }

        return dataSet.GetXml();
    }

Примечание: Я использовал метод DataSet.GetXml, потому что результирующий XML проще, и потому что вы можете получить странные ошибки , просто возвращая DataSet как есть.

0 голосов
/ 14 марта 2011

Нет, вы не можете этого сделать.Вы должны создать свой собственный класс с простыми типами и вернуть его.

...