Fonction PHP SimpleXMLElement :: addAttribute ()

Définition et utilisation

XML est un langage de balisage permettant de partager les données sur le Web, XML est à la fois lisible par l'homme et par machine. La classe SimpleXMLElement représente un document XML en PHP.

le SimpleXMLElement::addAttribute() La fonction accepte des valeurs de chaîne représentant le type et la valeur d'un attribut et ajoute l'attribut spécifié à l'élément SimpleXML.

Syntaxe

SimpleXMLElement::addAttribute($name [$value, $namespace ]);

Paramètres

Sr. Non Paramètre et description
1

name (Mandatory)

Il s'agit d'une valeur de chaîne représentant le nom de l'attribut à ajouter au SimpleXMLElement (fichier XML).

2

value(Optional)

Il s'agit d'une chaîne représentant la valeur de l'attribut à ajouter au SimpleXMLElement (fichier XML).

3

namespace(Optional)

Il s'agit d'une valeur de chaîne représentant l'espace de noms auquel appartient l'attribut.

Valeurs de retour

Cette fonction ne renvoie aucune valeur.

Version PHP

Cette fonction a été introduite pour la première fois dans la version 5 de PHP et fonctionne dans toutes les versions ultérieures.

Exemple

L'exemple suivant montre l'utilisation du SimpleXMLIterator::addAttribute() fonction.

<html>
   <head>
      <body>
         <?php
            $xmlstr="<?xml version='1.0' standalone='yes'?>
            <Tutorial>
               <Name>JavaFX</Name>
               <Pages>535</Pages>
               <Author>Krishna</Author>
               <Version>11</Version>
            </Tutorial>";
            $xml = new SimpleXMLElement($xmlstr);
            $xml->addAttribute('type', 'test');
            $tut = $xml->addChild('Tutorial');
            $tut->addChild('Price', '600');
    
            echo $xml->asXML();
            echo "<br><br>";
            print_r($xml);
         ?>      
      </body>
   </head>   
</html>

Cela produira le résultat suivant -

JavaFX 535 Krishna 11 600
SimpleXMLElement Object (
   [@attributes] => Array ( [type] => test ) 
   [Name] => JavaFX [Pages] => 535 
   [Author] => Krishna [Version] => 11 
   [Tutorial] => SimpleXMLElement Object ( [Price] => 600 ) 
)

Exemple

Voici un exemple de cette fonction avec un espace de nom de paramètre facultatif -

<html>
   <head>
      <body>
         <?php
            $str = "<?xml version='1.0' standalone='yes'?>
            <Tutorial>
               <Name>JavaFX</Name>
               <Pages>535</Pages>
               <Author>Krishna</Author>
               <Version>12</Version>
            </Tutorial>";
            $xml = new SimpleXMLElement($str);
            $xml->addAttribute("m:type", "test", 'mynamespace'); 
            print_r($xml);			 
         ?>      
      </body>
   </head>   
</html>

Cela produira la sortie suivante -

SimpleXMLElement Object ( 
   [Name] => JavaFX [Pages] => 535 
   [Author] => Krishna [Version] => 12 
)

Exemple

Dans l'exemple suivant, nous essayons de charger le contenu d'un fichier XML à l'aide des fonctions current () et next () et d'y ajouter un attribut -

Data.xml:

<?xml version="1.0" encoding="utf-8"?>
<Tutorials>
   <Tutorial>
      <Name>JavaFX</Name>
      <Pages>535</Pages>
      <Author>Krishna</Author>
      <Version>11</Version>
   </Tutorial>

   <Tutorial>
      <Name>CoffeeScript</Name>
      <Pages>235</Pages>
      <Author>Kasyap</Author>
      <Version>2.5.1</Version>
   </Tutorial>
</Tutorials>

Sample.xml

<html>
   <head>      
      <body>         
         <?php
            $doc = new DOMDocument;
            $xml = simplexml_load_file("Data.xml");
            
            //file to SimpleXMLElement 
            $simpleXmlElement = simplexml_import_dom($xml);
            $simpleXmlElement->addAttribute('type', 'test');
            print_r($xml);

            print("<br><br>");
            foreach($xml->children() as $tut) {       
               print($tut->Name ."<br>");
               print($tut->Pages ."<br>");
               print($tut->Author ."<br>");
               print($tut->Version ."<br>");
               print("<br>");
            }
         ?>
      </body>
   </head>
</html>

Cela produira le résultat suivant -

SimpleXMLElement Object ( [@attributes] => 
Array ( [type] => test ) [Tutorial] => 
Array ( [0] => SimpleXMLElement Object ( [Name] => 
JavaFX [Pages] => 535 [Author] => 
Krishna [Version] => 11 ) [1] => 
SimpleXMLElement Object ( [Name] => 
CoffeeScript [Pages] => 235 [Author] => 
Kasyap [Version] => 2.5.1 ) ) )

JavaFX
535
Krishna
11

CoffeeScript
235
Kasyap
2.5.1