Comparison of stylesheet languages

From Wikipedia, the free encyclopedia

The two primary stylesheet languages are Cascading Style Sheets (CSS) and the Extensible Stylesheet Language (XSL). While they are both called stylesheet languages, they have very different purposes and ways of going about their tasks.

Contents

[edit] Cascading Style Sheets

CSS is designed around styling HTML and XML (including XHTML) documents. It was created for that purpose. It uses a special, non-XML syntax for defining the styling information for the various elements of the document that it styles.

CSS, as of version 2.1, is best used for styling documents that are to be shown on "screen media". That is, media displayed as a single page (possibly with hyperlinks) that has a fixed horizontal width but a virtually unlimited vertical height. Scrolling is often the method of choice for viewing parts of paged media. This is in contrast to paged media, which has multiple pages, each with specific fixed horizontal and vertical dimensions. Styling paged media involves a variety of complexities that screen media does not. Since CSS was designed originally for screen media, its paged facilities are lacking.

CSS version 3.0 provides new features that allow CSS to more adequately style documents for paged display.

[edit] Extensible Stylesheet Language

XSL has evolved drastically from its initial design into something very different from its original purpose. The original idea for XSL was to create an XML-based styling language directed towards paged display media. The mechanism they used to accomplish this task was to divide the process into two distinct steps.

First, the XML document would be transformed into an intermediate form. The process for performing this transformation would be governed by the XSL stylesheet, as defined by the XSL specification. The result of this transformation would be an XML document in an intermediate language, known as XSL-FO (also defined by the XSL specification).

However, in the process of designing the transformation step, it was realized that a generic XML transformation language would be useful for more than merely creating a presentation of an XML document. As such, a new working group was split off from the XSL working group, and the XSL Transformations (XSLT) language became something that was considered separate from the styling information of the XSL-FO document. Even that split was expanded when XPath became its own separate specification, though still strongly tied to XSLT.

The combination of XSLT and XSL-FO creates a powerful styling language, though much more complex than CSS. XSLT is a turing complete language, while CSS is not; this demonstrates a degree of power and flexibility not found in CSS. Additionally, XSLT is capable of creating content, such as automatically creating a table of contents just from chapters in a book, or removing/selecting content, such as only generating a glossary from a book. XSLT version 1.0 with the EXSLT extensions, or XSLT version 2.0 is capable of generating multiple documents as well, such as dividing the chapters in a book into their own individual pages. By contrast, a CSS can only selectively remove content by not displaying it.

XSL-FO is unlike CSS in that the XSL-FO document stands alone. CSS modifies a document that attached to it, while the XSL-FO document (the result of the transformation by XSLT of the original document) contains all of the content to be presented in a purely presentational format. It has a wide range of specification options with regard to paged formatting and higher-quality typesetting. But it does not specify the pages themselves. The XSL-FO document must be passed through an XSL-FO processor utility that generates the final paged media, much like HTML+CSS must pass through a web browser to be displayed in its formatted state.

The complexity of XSL-FO is a problem, largely because implementing a FO processor is very difficult. CSS implementations in web browsers are still not entirely compatible with one another, and it is much simpler than writing a FO processor. However, for richly specified paged media, such complexity is ultimately required in order to be able to solve various typesetting problems.


[edit] See also

[edit] External links