JavaScriptSerializer.Deserialize Metod
Definition
Viktigt
En del information gäller för förhandsversionen av en produkt och kan komma att ändras avsevärt innan produkten blir allmänt tillgänglig. Microsoft lämnar inga garantier, uttryckliga eller underförstådda, avseende informationen som visas här.
Överlagringar
| Name | Description |
|---|---|
| Deserialize(String, Type) |
Konverterar en JSON-formaterad sträng till ett objekt av den angivna typen. |
| Deserialize<T>(String) |
Konverterar den angivna JSON-strängen till ett objekt av typen |
Deserialize(String, Type)
Konverterar en JSON-formaterad sträng till ett objekt av den angivna typen.
public:
System::Object ^ Deserialize(System::String ^ input, Type ^ targetType);
public object Deserialize(string input, Type targetType);
member this.Deserialize : string * Type -> obj
Public Function Deserialize (input As String, targetType As Type) As Object
Parametrar
- input
- String
JSON-strängen som ska deserialiseras.
- targetType
- Type
Typen av det resulterande objektet.
Returer
Det deserialiserade objektet.
Undantag
input är null.
Längden på input överskrider värdet för MaxJsonLength.
-eller-
Rekursionsgränsen som definierades av RecursionLimit överskreds.
-eller-
input innehåller en oväntad teckensekvens.
-eller-
input är en ordlistetyp och ett nyckelvärde som inte är sträng påträffades.
-eller-
input innehåller medlemsdefinitioner som inte är tillgängliga för måltypen.
input innehåller egenskapen "__type" som anger en anpassad typ, men den typlösare som för närvarande är associerad med serialiseraren kan inte hitta en motsvarande hanterad typ.
-eller-
input innehåller egenskapen "__type" som anger en anpassad typ, men resultatet av att deserialisera motsvarande JSON-sträng kan inte tilldelas till den förväntade måltypen.
-eller-
input innehåller egenskapen "__type" som anger antingen Object eller en icke-instansierbar typ (till exempel en abstrakt typ eller ett gränssnitt).
-eller-
Ett försök gjordes att konvertera en JSON-matris till en matrisliknande hanterad typ som inte stöds för användning som JSON-deserialiseringsmål.
-eller-
Det går inte att konvertera input till måltypen.
Kommentarer
Den här deserialiseringsmetoden försöker inte omvandla objektdiagrammets rot till en viss typ, som Deserialize metoden gör.
Gäller för
Deserialize<T>(String)
Konverterar den angivna JSON-strängen till ett objekt av typen T.
public:
generic <typename T>
T Deserialize(System::String ^ input);
public T Deserialize<T>(string input);
member this.Deserialize : string -> 'T
Public Function Deserialize(Of T) (input As String) As T
Typparametrar
- T
Typen av det resulterande objektet.
Parametrar
- input
- String
JSON-strängen som ska deserialiseras.
Returer
Det deserialiserade objektet.
Undantag
Längden input överskrider värdet för MaxJsonLength.
-eller-
Rekursionsgränsen som definierades av RecursionLimit överskreds.
-eller-
input innehåller en oväntad teckensekvens.
-eller-
input är en ordlistetyp och ett nyckelvärde som inte är sträng påträffades.
-eller-
input innehåller medlemsdefinitioner som inte är tillgängliga för typen T.
input är null.
input innehåller egenskapen "__type" som anger en anpassad typ, men den typlösare som är associerad med serialiseraren kan inte hitta en motsvarande hanterad typ.
-eller-
input innehåller egenskapen "__type" som anger en anpassad typ, men resultatet av att deserialisera motsvarande JSON-sträng kan inte tilldelas till den förväntade måltypen.
-eller-
input innehåller egenskapen "__type" som anger antingen Object eller en icke-instansierbar typ (till exempel en abstrakt typ eller ett gränssnitt).
-eller-
Ett försök gjordes att konvertera en JSON-matris till en matrisliknande hanterad typ som inte stöds för användning som JSON-deserialiseringsmål.
-eller-
Det går inte att konvertera input till T.
Exempel
I följande exempel visas en enkel bild av hur du serialiserar och deserialiserar dataobjekt.
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
Det kräver en klass med namnet Person, som visas i följande exempel.
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
Kommentarer
Metoden Deserialize motsvarar att först använda DeserializeObject metoden för att hämta ett objektdiagram och sedan försöka omvandla resultatet till att skriva T.
Under deserialiseringen refereras serialiserarens aktuella typlösare, som avgör vilken hanterad typ som ska användas vid konvertering av element som är kapslade i matriser och ordlistetyper. Därför itererar deserialiseringsprocessen genom alla kapslade element i input. Mer information om typlösare finns i JavaScriptTypeResolver klassen .