Hoe gebruik je XML

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Mark Hogeveen

Mark Hogeveen

10/11/2012 18:29:39
Quote Anchor link
Hallo ik heb wat info opgezocht over XML, het is dus eigenlijk niet meer dan een manier om data te ordenen in een bestand en om dit makkelijk te kunnen gebruiken bij andere dingen zoals programma's, PHP, of gewoon een HTML pagina.
Maar hoe haal je data uit een XML file met bijvoorbeeld javascript? Ik heb gelezen dat dit kan en ook veel wordt gebruikt.

Als ik bijvoorbeeld een applicatie heb met tientallen dialoogjes (zoals de dialog van jQuery)
Dan hoef ik dus niet bijvoorbeeld tientallen aparte divs te maken. Dan roep je zo'n dialoogje aan met javascript.

Hoe werkt dit? kan iemand me wat uitleg geven?
Gewijzigd op 10/11/2012 18:30:06 door Mark Hogeveen
 
PHP hulp

PHP hulp

24/11/2024 05:20:32
 
Wouter J

Wouter J

10/11/2012 19:25:18
Quote Anchor link
Je slaat de informatie gewoon op een in xml file, bijv:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
<!-- tasks.xml -->
<?xml version="1.0" encoding="utf-8" ?>

<tasks>
    <task id="1">
        <name>Harry helpen op PHPhulp</name>
        <time>18:45</time>
    </task>
    <task id="2">
        <name>Uit eten</name>
        <time>19:00</time>
    </task>
</tasks>


Nu laad je deze content in met AJAX (voor jQuery jQuery.ajax()). jQuery heeft een speciale XML versie van de AJAX functie die het meteen al omzet voor ons:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
$.ajax({
    url: 'tasks.xml',
    dataType: 'xml',
    success: function(result) {
        // result bevat nu het XML document
    }
});


Vervolgens kunnen we er gewoon dingen uit selecteren alsof we een element uit een normale HTML document halen:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
$.ajax({
    ...,
    success: function(result) {

        $('#2'); // selecteert <task id="2">...</task>
        $('task'); // selecteert alle <task ...>...</task> elementen

        $('#2 name'); // selecteert <task id="2"><name>...</name</task>
        $('name'); // selecteert alle <name>...</name> elementen

    }
});
 



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.