Разбор JSON в JavaScript после возврата JsonConvert.SerializeObject (json) [обработчик .NET] - PullRequest
2 голосов
/ 17 июля 2011

Я занимаюсь разработкой веб-приложения на платформе .net.

Я написал код обработчика, который возвращает объект JSON в Javascript (после запроса в AJAX).

Обработчиккод:

var wrapper = new { 
    left = left.ToString(), 
    top = top.ToString(), 
    width = width.ToString(), 
    height = height.ToString() };
context.Response.Write(JsonConvert.SerializeObject(wrapper));

В Javascript, когда я делаю предупреждение, я вижу, что я получаю объект.и это хорошо.
Но теперь я хочу разобрать его в JSON.

, когда я JSON.parse(msg); получаю ошибку

"JSON.parse: неожиданный символ"

, когда я jQuery.parseJSON(msg); использую jquery-1.6.2, я получаю эту ошибку

jQuery.parseJSON не является функцией (я использую jquery-1.6.2)

В чем проблема?

1 Ответ

2 голосов
/ 17 июля 2011

Попробуйте это.

Создайте страницу с именем TestPage.aspx следующим образом.

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>Test Page</title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js" type="text/javascript"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            $.ajax({
                url: 'TestPage.aspx/GetDimensions',
                type: 'POST',
                contentType: 'application/json',
                data: '{}',
                success: function (response) {
                    // Don't forget that the response is wrapped in a
                    //  ".d" object in ASP.NET 3.5 and later.
                    var data = response.d;
                    $('#test-div').animate({
                        left: data.left + 'px',
                        top: data.top + 'px',
                        height: data.height + 'px',
                        width: data.width + 'px'
                    }, 5000, function () {
                        // Animation complete.
                    });
                }
            });
        });
    </script>
    <style type="text/css">
        #test-div
        {
            background-color:#eee;
            border: 1px solid #ccc;
            border-radius: 5px;
            height: 100px;
            left:0px;
            padding-top: 40px;
            text-align:center;
            top:0px;
            width: 100px;
        }
    </style>
</head>
<body>
    <form id="form1" runat="server">

    <div id="test-div">
    This is a test div
    </div>

    </form>
</body>
</html>

И на TestPage.aspx.cs, сделайте это

using System.Web.Services;

public partial class Test1 : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e){/*page load eent*/}

    static int left = 50;
    static int top = 50;
    static int height = 200;
    static int width = 200;

    [WebMethod]
    public static object GetDimensions()
    {
        return new
        {
            left = left.ToString(),
            top = top.ToString(),
            width = width.ToString(),
            height = height.ToString()
        };
    }
}

Надеюсь, это поможет.

Предоставлено: Ошибка веб-служб ASP.NET: ручная сериализация JSON Дэйва Уорда

...