Dans le monde du décodage JSON, il peut arriver que vous rencontriez un objet imbriqué dont vous n'avez pas besoin de complètement analyser. Au lieu de cela, vous préférerez peut-être le traiter comme une chaîne brute ou un tableau d'octets. Voici un exemple de code illustrant cette approche :
package main import ( "encoding/json" "fmt" ) type Bar struct { ID int64 `json:"id"` Foo json.RawMessage `json:"foo"` } func main() { jsonStr := []byte(`{ "id" : 15, "foo" : { "foo": 123, "bar": "baz" } }`) var bar Bar if err := json.Unmarshal(jsonStr, &bar); err != nil { panic(err) } fmt.Printf("%+v\n", bar) }
Dans cet exemple, la structure Bar contient deux champs : ID et Foo. Le champ ID est un int64, tandis que le champ Foo est déclaré comme json.RawMessage. Ce type nous permet de conserver les octets JSON associés à l'objet imbriqué.
Lors du décodage du JSON, le champ RawMessage stockera les octets JSON bruts représentant l'objet imbriqué. Cela inclut tous les champs imbriqués dans cet objet, vous permettant d'y accéder plus tard si nécessaire.
Cette approche est utile lorsque vous souhaitez reporter l'analyse de parties spécifiques du JSON pour économiser des ressources de calcul. Il offre également une plus grande flexibilité dans la gestion des objets imbriqués sans qu'il soit nécessaire de définir des types personnalisés pour chaque objet.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!