如何使用C#string Builder制作简单的JSON对象

man*_*nas 5 asp.net jquery json

我是JSON的新手,并希望使用StringBuilder创建简单的JSON对象,这将通过jQuery Ajax调用进行查询.

[WebMethod]
public static string GetmyJSON()
{
    StringBuilder sb = new StringBuilder();       
    sb.Append("{firstname: \"Manas\",").Append("lastname : \"Tunga\"").Append("}");
    return sb.ToString();    

}
Run Code Online (Sandbox Code Playgroud)

在我的客户端代码中,我有:

.ajax({

        type: "POST",
        url: "simplePage.aspx/GetmyJSON",           
        data: "{}",
        contentType: 'application/json; charset=utf-8',
        dataType: 'json',

        success: function (data) {

            alert(data.d.firstname);             


        } // end of sucess

    }); // End of ajax
Run Code Online (Sandbox Code Playgroud)

但我的警告信息显示"未定义"而不是"玛纳斯".是否可以使用StringBuilder返回JSON对象?

Dar*_*rov 10

永远不要那样做.永远不要手动构建JSON.始终使用JSON序列化程序.或者在您的情况下,您甚至不需要这样做,因为ASP.NET webmethod运行时会照顾.您所要做的就是专注于您的业务需求,而不用担心管道问题.

例如,首先定义一个代表您的数据的模型:

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

然后让您的Web方法返回此模型,将所有序列化问题留给框架:

[WebMethod]
public static Person GetPerson()
{
    Person p = new Person();
    p.FirstName = "Manas";
    p.LastName = "Tunga";
    return p;
}
Run Code Online (Sandbox Code Playgroud)

现在只需从客户端使用此方法:

$.ajax({
    type: 'POST',
    url: 'simplePage.aspx/GetPerson',
    data: '{ }',
    contentType: 'application/json; charset=utf-8',
    success: function (data) {
        alert(data.d.FirstName);
        alert(data.d.LastName);
    }
});
Run Code Online (Sandbox Code Playgroud)

无需担心JSON,字符串构建器,......

如果您需要,还可以将复杂参数传递给Web方法:

public class Foo
{
    public string Bar { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

然后:

[WebMethod]
public static Person GetPerson(Foo foo)
{
    ...
}
Run Code Online (Sandbox Code Playgroud)

最后:

$.ajax({
    type: 'POST',
    url: 'simplePage.aspx/GetPerson',
    data: JSON.stringify({ foo: { bar: 'baz' } }),
    contentType: 'application/json; charset=utf-8',
    success: function (data) {
        alert(data.d.FirstName);
        alert(data.d.LastName);
    }
});
Run Code Online (Sandbox Code Playgroud)

JSON.stringify此处显示的方法本身内置于现代浏览器中.如果您需要支持旧版浏览器,可以在页面中包含json2.js脚本.


Roy*_*mir 3

var lstMes = new List<Person>();

            System.Web.Script.Serialization.JavaScriptSerializer oSerializer =
             new System.Web.Script.Serialization.JavaScriptSerializer();
                string sJSON = oSerializer.Serialize(lstMes);
                return sJSON;
Run Code Online (Sandbox Code Playgroud)

不要忘记添加对以下内容的引用:

System.Web.Extensions.dll !!
Run Code Online (Sandbox Code Playgroud)