JavaScriptSerializer.Serialize Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Converte um objeto numa string JSON.
Sobrecargas
| Name | Description |
|---|---|
| Serialize(Object) |
Converte um objeto numa string JSON. |
| Serialize(Object, StringBuilder) |
Serializa um objeto e escreve a string JSON resultante no objeto especificado StringBuilder . |
Serialize(Object)
Converte um objeto numa string JSON.
public:
System::String ^ Serialize(System::Object ^ obj);
public string Serialize(object obj);
member this.Serialize : obj -> string
Public Function Serialize (obj As Object) As String
Parâmetros
- obj
- Object
O objetivo a serializar.
Devoluções
A cadeia JSON serializada.
Exceções
A cadeia JSON resultante excede o valor de MaxJsonLength.
-ou-
obj contém uma referência circular. Uma referência circular ocorre quando um objeto filho tem uma referência a um objeto pai, e o objeto pai tem uma referência ao objeto filho.
O limite de recursão definido por RecursionLimit foi ultrapassado.
Exemplos
O exemplo seguinte fornece uma ilustração simples de como serializar e desserializar objetos de dados.
using System;
using System.Collections.Generic;
using System.Web.UI;
using System.Web.Script.Serialization;
namespace ExampleApplication
{
public partial class _Default : Page
{
protected void Page_Load(object sender, EventArgs e)
{
var RegisteredUsers = new List<Person>();
RegisteredUsers.Add(new Person() { PersonID = 1, Name = "Bryon Hetrick", Registered = true });
RegisteredUsers.Add(new Person() { PersonID = 2, Name = "Nicole Wilcox", Registered = true });
RegisteredUsers.Add(new Person() { PersonID = 3, Name = "Adrian Martinson", Registered = false });
RegisteredUsers.Add(new Person() { PersonID = 4, Name = "Nora Osborn", Registered = false });
var serializer = new JavaScriptSerializer();
var serializedResult = serializer.Serialize(RegisteredUsers);
// Produces string value of:
// [
// {"PersonID":1,"Name":"Bryon Hetrick","Registered":true},
// {"PersonID":2,"Name":"Nicole Wilcox","Registered":true},
// {"PersonID":3,"Name":"Adrian Martinson","Registered":false},
// {"PersonID":4,"Name":"Nora Osborn","Registered":false}
// ]
var deserializedResult = serializer.Deserialize<List<Person>>(serializedResult);
// Produces List with 4 Person objects
}
}
}
Imports System.Web.Script.Serialization
Public Class _Default
Inherits Page
Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load
Dim RegisteredUsers As New List(Of Person)()
RegisteredUsers.Add(New Person With {.PersonID = 1, .Name = "Bryon Hetrick", .Registered = True})
RegisteredUsers.Add(New Person With {.PersonID = 2, .Name = "Nicole Wilcox", .Registered = True})
RegisteredUsers.Add(New Person With {.PersonID = 3, .Name = "Adrian Martinson", .Registered = False})
RegisteredUsers.Add(New Person With {.PersonID = 4, .Name = "Nora Osborn", .Registered = False})
Dim serializer As New JavaScriptSerializer()
Dim serializedResult = serializer.Serialize(RegisteredUsers)
' Produces string value of:
' [
' {"PersonID":1,"Name":"Bryon Hetrick","Registered":true},
' {"PersonID":2,"Name":"Nicole Wilcox","Registered":true},
' {"PersonID":3,"Name":"Adrian Martinson","Registered":false},
' {"PersonID":4,"Name":"Nora Osborn","Registered":false}
' ]
Dim deserializedResult = serializer.Deserialize(Of List(Of Person))(serializedResult)
' Produces List with 4 Person objects
End Sub
End Class
Requer uma classe chamada Person, que é mostrada no exemplo seguinte.
namespace ExampleApplication
{
public class Person
{
public int PersonID { get; set; }
public string Name { get; set; }
public bool Registered { get; set; }
}
}
Public Class Person
Public Property PersonID As Integer
Public Property Name As String
Public Property Registered As Boolean
End Class
Observações
Quando a JavaScriptSerializer instância está a serializar um tipo para o qual está registado um conversor personalizado, o serializador chama o Serialize método para obter o dicionário de pares nome/valor que serão convertidos numa cadeia JSON.
O Serialize método também pode lançar exceções se o grafo-objeto for demasiado complexo, ou se instâncias registadas de JavaScriptConverter causaram recursão no conversor.
Aplica-se a
Serialize(Object, StringBuilder)
Serializa um objeto e escreve a string JSON resultante no objeto especificado StringBuilder .
public:
void Serialize(System::Object ^ obj, System::Text::StringBuilder ^ output);
public void Serialize(object obj, System.Text.StringBuilder output);
member this.Serialize : obj * System.Text.StringBuilder -> unit
Public Sub Serialize (obj As Object, output As StringBuilder)
Parâmetros
- obj
- Object
O objetivo a serializar.
- output
- StringBuilder
O StringBuilder objeto que é usado para escrever a cadeia JSON.
Exceções
A cadeia JSON resultante excede o valor de MaxJsonLength.
-ou-
obj contém uma referência circular. Uma referência circular ocorre quando um objeto filho tem uma referência a um objeto pai, e o objeto pai tem uma referência ao objeto filho.
O limite de recursão definido por RecursionLimit foi ultrapassado.
output é null.
Observações
Quando a JavaScriptSerializer instância está a serializar um tipo para o qual está registado um conversor personalizado, o serializador chama o Serialize método para obter o dicionário de pares nome/valor que serão convertidos numa cadeia JSON.
O Serialize método também pode lançar exceções se o grafo-objeto for demasiado complexo, ou se instâncias registadas de JavaScriptConverter causaram recursão no conversor.