- Inleiding tot XSLT
- Boeken:-
- Boeken:-
- Boeken:-
- Boeken:-
- Boeken:-
- Boeken:-
- Boeken:-
- Boeken:-
- Boeken:-
- Lijst van boeken Naam :-
- Lijst van boeken Naam :-
- Conclusie
Deze tutorial legt uit wat XSLT is, de transformaties, de elementen en het gebruik ervan met een voorbeeld. Ook het belang van XPath om XSLT-conversiecode te ontwikkelen komt aan bod:
De term "XSLT" is ontstaan door de combinatie van twee woorden, namelijk "XSL" en "T". "XSL" is de afkorting van "Extensible Stylesheet Language" en "T" is de afkorting van "Transformation".
XSLT is dus eigenlijk een transformatietaal die wordt gebruikt om XML-bronnen om te zetten in XML-documenten of in andere formaten zoals HTML, PDF met behulp van XSL-FO (Formatting Objects), enz.
Inleiding tot XSLT
De transformatie gebeurt met behulp van de XSLT-processor (zoals Saxon, Xalan). Deze XSLT-processor neemt een of meer XML-documenten als bron met een XSLT-bestand waarin XSLT-code is geschreven en de resultaat-/uitvoerdocumenten worden later gegenereerd, zoals weergegeven in het onderstaande diagram.
De XSLT-processor parseert de XML-brondocumenten door X-Path te gebruiken om over verschillende bronelementen te navigeren, beginnend bij het basiselement tot het einde van de documenten.
Alles wat u moet weten over X-Path
XSLT-transformatie
Om met de transformatie te beginnen hebben we een XML-document nodig waarop de XSLT-code zal worden uitgevoerd, het XSLT-codebestand zelf en de tool of software met XSLT-processor (U kunt elke gratis versie of proefversie van de software gebruiken om te leren).
#1) XML-code
Hieronder staat de XML-broncode waarop de XSLT-code zal draaien.
Bestandsnaam: Books.xml
XSLT Programmer's Reference Michael Kay Wrox $40 4e Head First Java Kathy Sierra O'reilly $19 1e SQL The Complete Reference James R. Groff McGraw-Hill $45 3e
#2) XSLT-code
Hieronder staat de XSLT-code op basis waarvan het bovenstaande XML-document wordt uitgevoerd.
Bestandsnaam: Books.xsl
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
#3) Resultaat/uitvoercode
De onderstaande code wordt geproduceerd na gebruik van de XSLT-code op het bovenstaande XML-document.
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
5350192956 | Naslagwerk voor XSLT-programmeurs | Michael Kay | Wrox | $40 | 4e |
3741122298 | Head First Java | Kathy Sierra | O'reilly | $19 | 1e |
9987436700 | SQL De volledige referentie | James R. Groff | McGraw-Hill | $45 | 3e |
#4) Resultaat/uitvoer bekijken in webbrowser
Boeken:
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
5350192956 | Naslagwerk voor XSLT-programmeurs | Michael Kay | Wrox | $40 | 4e |
3741122298 | Head First Java | Kathy Sierra | O'reilly | $19 | 1e |
9987436700 | SQL De volledige referentie | James R. Groff | McGraw-Hill | $45 | 3e |
XSLT-elementen
Om bovenstaande XSLT-code en de werking ervan te begrijpen, moeten we eerst de verschillende XSLT-elementen en hun attributen begrijpen.
#1) OF
Elke XSLT-code moet beginnen met het root-element ofwel of
Attributen:
- @xmlns:xsl: Verbindt XSLT-document met XSLT-standaard.
- @versie: Definieert de versie van de XSLT-code aan de parser.
#2)
Deze verklaring definieert een reeks regels die worden toegepast om het geselecteerde invoerelement van het brondocument te verwerken of te transformeren naar de gedefinieerde doelelementregels van de uitvoerdocumenten.
In principe zijn er twee soorten sjablonen beschikbaar, afhankelijk van hun kenmerken:
(i) Named Template: Wanneer het xsl: template element het @name attribuut bevat, wordt dit Named Template genoemd.
Genoemde sjablonen worden aangeroepen door het xsl:call-template element.
(ii) Match Template: Het xsl:template element bevat het @match attribuut dat een bijpassend patroon of XPath bevat dat op de ingangsknooppunten wordt toegepast.
Overeenkomende sjablonen worden aangeroepen door het xsl:apply-template element.
Een xsl:template-element dat geen match-attribuut heeft, mag geen mode-attribuut en geen priority-attribuut hebben.
Laten we de bovenstaande XSLT(
a) XSLT-code gebaseerd op Match Template met . Zie onderstaande gele & grijs gemarkeerde gewijzigde code, het zal hetzelfde bovenstaande outputresultaat opleveren.
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|
Zie de schermafbeelding voor het gemarkeerde gebied:
b) XSLT-code gebaseerd op de Named Template met . Zie onderstaande gele & grijs gemarkeerde gewijzigde code, het zal hetzelfde bovenstaande uitvoerresultaat opleveren.
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|
Zie de schermafbeelding voor het gemarkeerde gebied:
#3)
De verwerker zal alle sjablonen vinden en toepassen die XPath hebben gedefinieerd in het @select attribuut.
Het @mode attribuut wordt ook gebruikt als we meer dan één manier van uitvoer willen geven met dezelfde invoerinhoud.
#4)
De verwerker zal een oproep doen aan de sjablonen met de waarde in het @name attribuut (vereist).
element wordt gebruikt om parameters door te geven aan het sjabloon.
#5)
Geef de string/tekst waarde met betrekking tot de XPath expressie gedefinieerd in het @select attribuut, zoals gedefinieerd in de bovenstaande code.
Dit geeft de waarde van de boeknaam.
#6) : Herhaling
Dit zal de instructies verwerken voor elke reeks knooppunten (xpath gedefinieerd in het @select (vereist) attribuut) in de gesorteerde volgorde.
De bovenstaande code betekent voor elk knooppunt een set winkel/boeken:
/store/book[1]
/store/book[2]
/store/book[3]
kan ook worden gebruikt als child van xsl:for-each om de sorteervolgorde te bepalen.
#7) : Voorwaardelijke verwerking
De xsl:if instructies worden alleen verwerkt als de Booleaanse waarde van het @test attribuut waar is, anders wordt de instructie niet geëvalueerd en wordt de lege reeks geretourneerd.
2"> Condition True: Het aantal boeken is meer dan twee.
Resultaat: Voorwaarde Waar: Het aantal boeken is meer dan twee.
Hier is count() de voorgedefinieerde functie.
#8) : Alternatieve voorwaarden verwerking
xsl:choose heeft meerdere oorzaken voor verschillende voorwaarden die worden getest binnen @test attribuut van de xsl:when elementen, de testvoorwaarde die het eerst uitkomt van alle xsl:when, die zal het eerst worden verwerkt en er is een optioneel xls:otherwise element zodat als geen van de voorwaarden tests uitkomen dan zal deze xsl:otherwise worden beschouwd.
Voorwaarde Waar: De telling van het boek is één. Voorwaarde Waar: De telling van het boek is twee. Voorwaarde Waar: De telling van het boek is drie. Geen voorwaarde komt overeen.
Resultaat: Voorwaarde Waar: De telling van het boek is drie.
#9)
xsl:copy werkt op het context-item, d.w.z. als dat een node is, zal het de context node kopiëren naar de nieuw gegenereerde node en dit zal niet de kinderen van de context node kopiëren. Om deze reden wordt dit een ondiepe kopie genoemd. In tegenstelling tot het xsl:copy-of element, heeft de xsl:copy niet het@select attribuut.
In de onderstaande code worden de context items gekopieerd naar output & alle children items worden & gekopieerd door de xsl:apply-template recursief.
knooppunt() Staat voor alle knooppunten en al hun attributen recursief.
Resultaat: Dit kopieert alle knooppunten en attributen van het brondocument recursief naar het uitvoerdocument, d.w.z. het maakt een exacte kopie van het brondocument.
#10)
xsl:copy-of zal de reeks knooppunten met al zijn kinderen en attributen standaard recursief kopiëren, vanwege deze aard wordt dit ook wel diep kopiëren genoemd. Het @select attribuut is vereist voor de evaluatie van het XPath.
Resultaat: Dit kopieert alle knooppunten en attributen van het brondocument recursief naar het uitvoerdocument, d.w.z. het maakt een exacte kopie van het brondocument.
Staat voor een kopie van het huidige knooppunt en het huidige attribuut.
#11)
Dit element wordt gebruikt om een commentaar naar het doelresultaat te schrijven; elke tekstinhoud die aan deze tag voldoet, wordt afgedrukt als uitvoer met commentaar.
Dit wordt in de uitvoer afgedrukt als een commentaarknooppunt.
Resultaat:
#12)
Dit genereert een tekstknooppunt in het resultatendocument, de waarde in de xsl:text wordt afgedrukt als een string in de uitvoer.
Dit is een
tekstregel.
Uitgang:
Dit is een
tekstregel.
#13)
Dit genereert een element in het resultatendocument met de naam die in het @name attribuut staat. Het name attribuut is het verplichte attribuut.
Resultaat: 5350192956
#14)
De naam van het attribuut wordt bepaald door het name attribuut en de waarde van het attribuut wordt berekend door het XPath in het select attribuut zoals in de onderstaande code. Het name attribuut is het vereiste attribuut.
Resultaat:
#15)
Dit element sorteert het geselecteerde knooppunt in oplopende of aflopende volgorde. Het knooppunt of XPath wordt gegeven met het @select attribuut en de sorteerrichting wordt bepaald met het @order attribuut.
In de onderstaande code krijgen we een lijst met alle boeken in alfabetische volgorde.
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
Zie deze schermafbeelding voor het gemarkeerde gebied:
Resultaat: De onderstaande lijst bevat de boeknamen in alfabetische volgorde, d.w.z. in oplopende volgorde.
Boeken:
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
3741122298 | Head First Java | Kathy Sierra | O'reilly | $19 | 1e |
9987436700 | SQL De volledige referentie | James R. Groff | McGraw-Hill | $45 | 3e |
5350192956 | Naslagwerk voor XSLT-programmeurs | Michael Kay | Wrox | $40 | 4e |
#16)
Dit element geeft een variabele aan die een waarde bevat. Een variabele kan een globale variabele of een lokale variabele zijn. De naam van de variabele wordt gedefinieerd door het @name attribuut en de waarde die deze variabele zal bevatten wordt gedefinieerd door het @select attribuut.
De toegang tot de globale variabele is globaal, d.w.z. de variabelen kunnen in elk element worden aangeroepen en blijven toegankelijk binnen het stylesheet.
Om een globale variabele te definiëren, hoeven we alleen maar aan te geven dat naast het root-element van het stylesheet, zoals in de onderstaande code in het geel gemarkeerd, de variabele 'SecondBook' de globale variabele is, die de naam van het tweede boek bevat.
De toegang tot de lokale variabele is lokaal voor het element waarin zij is gedefinieerd, d.w.z. dat de variabele niet toegankelijk is buiten het element waarin zij is gedefinieerd, zoals blijkt uit de onderstaande code die grijs gemarkeerd is: de variabele "eerste boek" is een lokale variabele en bevat de naam van het eerste boek.
Om een oproep te doen naar de globale variabele naar de lokale variabele wordt het dollarteken ($) gebruikt vóór de naam van de variabele, zoals hieronder geel gemarkeerd is $ .
Eerste boeknaam: Tweede boeknaam:
Zie de schermafbeelding voor het gemarkeerde gebied:
Resultaat:
Eerste boeknaam: XSLT Programmer's Reference
Tweede boeknaam: Head First Java
#17)
Dit element wordt gebruikt om sleutels aan te geven, voor de bijpassende patroonwaarden bij die bepaalde sleutel.
Naam is een aanbieder van die sleutel door @naam attribuut(" get-publisher "), die later wordt gebruikt in de key() functie. @match attribuut wordt verstrekt om input node te indexeren door XPath expressies(" boek "), zoals in de onderstaande geel gemarkeerde @match wordt gebruikt om te indexeren op alle boeken die beschikbaar zijn in de winkel.
Ten opzichte van het @match attribuut wordt het @use attribuut gebruikt, dat het knooppunt verklaart om de waarde voor die sleutel te verkrijgen via een XPath expressie("publisher").
Stel nu dat we de details nodig hebben van het boek dat alleen door uitgeverij 'Wrox' wordt uitgegeven, dan kunnen we die waarde gemakkelijk krijgen via het xsl:key element door een key-value paar te maken.
sleutel("get-publisher", "Wrox") Key() neemt twee parameters, de eerste is de naam van de sleutel, die in dit geval 'get-publisher' is, de tweede is de string die gezocht moet worden, die in ons geval 'Wrox' is.
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
Zie de schermafbeelding voor het gemarkeerde gebied:
Resultaat:
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
5350192956 | Naslagwerk voor XSLT-programmeurs | Michael Kay | Wrox | $40 | 4e |
Resultaat / HTML-weergave:
Boeken:
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
5350192956 | Naslagwerk voor XSLT-programmeurs | Michael Kay | Wrox | $40 | 4e |
#18)
Dit element wordt gebruikt voor debugging doeleinden in XSLT ontwikkeling. Het element geeft zijn uitvoer naar het standaard uitvoer scherm van de applicatie.
Het @terminate attribuut wordt gebruikt met twee waarden: "ja" of "nee". Als de waarde wordt ingesteld op "ja", wordt de parser onmiddellijk beëindigd zodra aan de testvoorwaarde is voldaan, zodat het bericht kan worden uitgevoerd.
Om dit te begrijpen, stel dat in ons invoerdocument het prijselement per ongeluk leeg is, zoals in de onderstaande code, dan moet de verwerking onmiddellijk stoppen zodra de processor het lege prijselement tegenkomt, wat gemakkelijk kan worden bereikt door xsl:message te gebruiken in de if-testvoorwaarde zoals in de onderstaande XSLT-code.
Debugger-waarschuwing wordt getoond door het standaardscherm van de toepassing: Verwerking beëindigd door xsl:message op regel 21.
Input XML code:
SQL The Complete Reference James R. Groff McGraw-Hill 3rd
Zie screenshot voor het gemarkeerde gebied:
XSLT-code:
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
Zie de schermafbeelding voor het gemarkeerde gebied:
Resultaat: Merk op dat zodra de parser de lege prijstag tegenkomt, hij de verwerking onmiddellijk beëindigt, waardoor de eindtags van , en niet aan het einde van het bestand zouden komen.
Boeken:-
Boek ID | Naam van het boek | Naam van de auteur | Uitgever | Prijs | Editie |
---|---|---|---|---|---|
5350192956 | Naslagwerk voor XSLT-programmeurs | Michael Kay | Wrox | $40 | 4e |
3741122298 | Head First Java | Kathy Sierra | O'reilly | $19 | 1e |
Zie screenshot voor het gemarkeerde gebied:
#19) &
element definieert de parameter van de template indien deze binnenin is gedefinieerd. Hij kan zowel binnenin worden gedefinieerd als globale parameter of binnenin als lokale parameter van die template.
De waarde van de wordt doorgegeven/geleverd wanneer het sjabloon wordt aangeroepen door of .
geeft het de waarde door van de parameter gedefinieerd in Attribuut als @name bevat de naam van de parameter die moet overeenkomen met het @name attribuut van het element. @Select attribuut wordt gebruikt om een waarde aan die parameter toe te kennen.
Om de waarde van de parameter op te halen wordt net als bij een variabele het dollarteken ($) gebruikt.
Broncode XML:
XSLT Programmer's Reference Michael Kay Wrox $40 4e Head First Java Kathy Sierra O'reilly $19 1e SQL The Complete Reference James R. Groff McGraw-Hill $45 3e
XSLT-code:
Lijst van boeken Naam :-
Naam van het boek:
Zie screenshot voor het gemarkeerde gebied:
Resultaat Output:
Lijst van boeken Naam :-
Boeknaam: XSLT Programmer's Reference
Naam boek: Head First Java
Boeknaam: SQL The Complete Reference
#20)
wordt gebruikt om een andere stylesheet-module in ons huidige stylesheet te importeren. Dit helpt bij het bereiken van een modulaire XSLT-ontwikkelingsaanpak.
Na het importeren komen alle sjablonen beschikbaar voor gebruik. De prioriteit van de sjablonen die in het bovenliggende stylesheet (dat een ander stylesheet importeert) zijn gedefinieerd, is hoger dan die van het geïmporteerde stylesheet (dat door het bovenliggende stylesheet wordt geïmporteerd).
Als een ander stylesheet ook dezelfde naam template heeft als gedefinieerd in het template dat wordt geïmporteerd, dan worden de buitenlandse templates overschreven door uw eigen template.
Het attribuut @href wordt gebruikt als de URI van het stylesheet dat u wilt importeren.
#21)
Hetzelfde als de bovenstaande xsl:import, helpt ook bij het bereiken van een modulaire XSLT-ontwikkeling. Alle templates die worden opgenomen door hebben dezelfde prioriteit/voorrang als het aanroepende stylesheet. Het is alsof je alle templates van een ander stylesheet kopieert naar je eigen stylesheet.
Het attribuut @href wordt gebruikt als de URI van het stylesheet dat u wilt importeren.
#22)
Dit element wordt gebruikt om de resultaatstructuur in het uitvoerbestand te specificeren. Het bevat attributen zoals @method die waarden kunnen hebben als 'XML', 'HTML', 'XHTML' en 'tekst'. Standaard is dit 'XML'.
@encoding specificeert de tekencodering die in het uitvoerbestand komt zoals in onderstaand voorbeeld encoding="UTF-16″, de standaardwaarden voor XML of XHTML kunnen UTF-8 of UTF-16 zijn. @indent specificeert de inspringing van de XML- of HTML-uitvoercode, voor XML is de standaardwaarde 'nee' en voor HTML en XHTML is de standaardwaarde 'ja'.
#23)
Dit element wordt gebruikt voor het strippen (verwijderen) van niet-significante witruimte voor het vermelde bronelement in het @element-attribuut en als we witruimte willen strippen van alle elementen, kunnen we '*' gebruiken in het @element-attribuut.
#24)
Dit element wordt gebruikt om witruimte te behouden voor het vermelde bronelement binnen het @element attribuut en als we witruimte willen behouden voor alle elementen, kunnen we '*' gebruiken binnen het @elements attribuut.
Conclusie
Dus in dit artikel hebben we geleerd over XSLT, vaak gebruikte XSLT-elementen, hun gebruik met voorbeeldbron- en doel/resultaatcode, conversie of transformatie van het bronelement naar het doelelement.
We hebben ook het belang van XPath besproken om XSLT-conversiecode te ontwikkelen. We hebben de XSL-template-declaratie en template calling & gezien; het doorgeven van parameters. We hebben geleerd globale en lokale variabelen te declareren, hun gebruik in de XSLT-code, en hoe ze aan te roepen.
We leerden over verschillende vertakkende of voorwaardelijke XSLT-elementen zoals xsl:if, xsl:for-each, xsl:choose. We begrepen het verschil tussen oppervlakkig kopiëren en diep kopiëren, het sorteren van knooppunten, het debuggen van XSLT-code met behulp van xsl:message, het verschil tussen named templates en match templates, en uitvoeropmaak met behulp van xsl:output.
Over de auteur : Himanshu P. is een ervaren professional op het gebied van informatietechnologie. Hij heeft bij ITC MNC's gewerkt aan cross-business domeinen en meerdere technologieën. Himanshu's favoriete bezigheid is het lezen van tijdschriften en bloggen.