Maison >interface Web >js tutoriel >Pourquoi JSON.stringify ne parvient-il pas à stringifier les objets d'erreur et comment puis-je y remédier ?

Pourquoi JSON.stringify ne parvient-il pas à stringifier les objets d'erreur et comment puis-je y remédier ?

Patricia Arquette
Patricia Arquetteoriginal
2024-11-29 21:53:10577parcourir

Why Does JSON.stringify Fail to Stringify Error Objects and How Can I Fix It?

JSON.stringify : impossible de chaîner les objets d'erreur

Lorsque vous travaillez avec des sockets Web et que vous rencontrez des erreurs, il est souvent nécessaire de transmettre des messages d'erreur. Au départ, l'utilisation de JSON.stringify semble être une solution simple, mais elle ne chaîne pas correctement les objets Error natifs.

Problème :

Tentative de chaîner les résultats d'un objet Error. dans un objet vide ({}), indiquant que les informations de l'erreur n'étaient pas capturé.

Cause :

Le problème réside dans les propriétés du prototype de l'objet Erreur. Les propriétés clés telles que la pile et le message ont leur indicateur énumérable défini sur false. Par conséquent, JSON.stringify ignore ces propriétés lors du processus de sérialisation, vous laissant avec un objet vide.

Solution :

Pour contourner ce comportement, il est nécessaire d'extraire manuellement les propriétés de l'objet Error à l'aide de Object.getOwnPropertyNames. Ces propriétés peuvent ensuite être transmises à JSON.stringify en tant que fonction de remplacement pour créer une chaîne JSON incluant les informations sur l'erreur :

JSON.stringify(err, Object.getOwnPropertyNames(err))

Vous pouvez également créer vos propres objets d'erreur personnalisés avec des propriétés énumérables, leur permettant d'être stringifiés correctement par JSON.stringify.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn