Home >Backend Development >PHP Tutorial >Middle school education review materials php xml introductory study materials
Cause:
I encountered a problem while working on a project today: I need to dynamically update the pictures on the homepage to show that this site is not just finished, but that someone has been maintaining it. Okay, now that the requirement is there, how to implement it? !
My thoughts are as follows:
Picture storage location: Put it in a folder; Picture type: It cannot be fixed, as long as it is a picture, it can be uploaded and displayed; Picture name: The original name is a bit irregular and should be renamed.
Display position: This requires specifying the corresponding id for the picture. This id is fixed and must correspond to the picture one-to-one. So there is a relationship file with one-to-one correspondence between records. You can choose csv files, database records, and finally decided to choose xml. I never learned this thing in school, and I have always avoided using it for fear of trouble. Today was a challenge. After spending an afternoon, I finally gained something.
Learning steps:
Clear goals: 1. Understand the structure of xml; 2. How to dynamically create xml files; 3. How to read and modify xml files
1. The structure of xml is a tree structure:
This is easy to understand. Simply write one:
Copy the code The code is as follows:
Second, I use PHP to create:
1. Define a DOM object: $dom = new DomDocument('1.0');
2. Add child elements: $dom->appendChild($dom->createElement(" pictures"))
The prototype in the memory is:
Continue to add child elements: *->appendChild($dom->createElement("picture"));
Continue to add : **->appendChild($dom->createElement("id"));
ifier. ***->appendChild($dom->createNode("1") )
The * above represents the previous line of code; this way it can be written in one line:
$dom->appendChild($dom->createElement("pictures"))->appendChild($dom-> createElement("picture"))
->appendChild($dom->createElement("id"))->appendChild($dom->createNode("1"));
The memory should look like this now :
forth, can easily be confused.
Therefore it is generally written like this: $pictures = $dom->appendChild($dom->createElement("pictures"));
$picture = $pictures->appendChild($dom->createElement("picture" ));
$id = $picture->appendChild($dom->createElement("id")); You can also create the name node:
$name = $picture->appendChild($dom->createElement("name"));
));
Next, we need to create the picture node:
$picture = $pictures->appendChild($dom->createElement("picture"));
In fact, these troublesome things can be realized by writing a for loop .
Generate xml file:
$dom->formatOutput = true;//Set formatted output
$dom->save("erhsh.xml");//Save the xml file
3. Read the xml file.
1. Define a DOM object; $dom->new DomDocument();
2. Load the xml file: $dom->load("erhsh.xml");
3. Obtain the node collection according to the name of the node :$dom->getElementByTagName("pictures");
This method is a bit troublesome, reference file:
http://www.jb51.net/article/25853.htm
But there is a method I like: simplexml_load_file( "erhsh.xml");
This method can convert the content of the xml file into the form of an object. It is easy to get the content of the xml using the "->" knot and "[]";
But we still encountered this problem during development A little question:
When executing: print_r($xml->pictures);, the output is a SimpleXMLElement object, ([picture] => array([0]=>array(...)[1]= >array(...)));
Execute again: print_r($xml->pictures->picture); The output is n separate objects.
Execution: print_r($xml->pictures->picture[0]->id); The output is still an object. This is very incomprehensible, it should be a string. Finally, it is said on the Internet that it is an "iteration object", and echo output should be used. The output of print_r() and var_dump() is inaccurate. Reference address: http://www.jb51.net/article/25852.htm
Of course, you can also modify the value of xml through this method.
The writing is terrible, just for me to keep in mind.
The above introduces the middle school education review materials php xml introductory study materials, including the content of the middle school education review materials. I hope it will be helpful to friends who are interested in PHP tutorials.