Malgré l'utilisation des fonctions PHP DOM pendant une période prolongée, l'affiche originale (OP) a exprimé des difficultés à comprendre leur fonctionnalité. Ils ont fourni un échantillon XML et ont décrit deux problèmes spécifiques rencontrés :
L'OP utilisait la fonction setIdAttribute pour définir les identifiants des éléments de la page afin d'éviter la duplication lors du chargement. dans l'arbre. Cependant, ils ont rencontré des difficultés en essayant de récupérer ces identifiants à l'aide de getElementById.
Solution :
Pour résoudre ce problème, il est conseillé à l'OP d'utiliser l'attribut xml:id au lieu de l'attribut id traditionnel. Cette approche ne nécessite pas de DTD ou de schéma et permet au DOM de reconnaître les attributs d'ID sans validation.
Pour minimiser les données chargées, l'OP a initialement créé des attributs d'ID sur les pages. Cependant, en raison des limitations de getElementById, ils ont opté pour XPath pour récupérer les informations nécessaires.
Solution :
Au lieu de s'appuyer sur getElementById, ce qu'ils prétendent faire ne fonctionne pas correctement sur sa plate-forme, l'OP peut exploiter XPath pour interroger le XML sur des pages spécifiques et leurs éléments enfants. Cette solution offre une approche plus efficace et polyvalente pour récupérer les données requises.
Exemple :
Pour récupérer tous les produits d'une page spécifique avec l'ID « 1 » à l'aide de XPath :
<code class="php">$xpath->query('/pages/page[@id="1"]/products');</code>
En réponse à un commentaire, l'OP fournit une explication plus détaillée :
Utilisation de l'attribut XML:ID :
Lors de la définition d'un attribut ID à l'aide de l'attribut xml:id, l'instance DOM peut le reconnaître sans nécessiter de DTD ou de schéma. Ceci est défini par le W3C et fonctionne indépendamment de la plateforme ou de la version de libxml.
Limitations de l'attribut ID sans espace de noms :
Si un attribut ID est défini sans le XML :id espace de noms, le DOM le traitera comme un attribut normal. Pour le reconnaître comme un attribut d'ID, une DTD ou un schéma doit être spécifié et le XML doit être validé par rapport à celui-ci.
XPath reste une méthode polyvalente et fiable pour interroger des documents XML, en particulier lorsque des attributs d'ID sont impliqués. Il élimine la dépendance à getElementById et offre la flexibilité de récupérer des éléments spécifiques en fonction de divers critères.
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!