Стивен Холзнер - XSLT
- Название:XSLT
- Автор:
- Жанр:
- Издательство:Питер
- Год:2002
- Город:Санкт-Петербург
- ISBN:5-94723-271-5
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Стивен Холзнер - XSLT краткое содержание
Эта книга посвящена XSLT — мощным и удобным системам преобразования документов. В ней не только рассматривается весь синтаксис XSLT, от основ до специальных аспектов, но и подробно излагаются современные способы использования XSLT.
Вы найдете сотни практических примеров, таких как осуществление преобразований XSLT на web-cepвepax, подключение к базам данных и использование браузеров для осуществления преобразований на лету.
Книга рассчитана на всех, кто хочет изучать XSLT и использовать его на практике
XSLT - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
• ASP. http://msdn.microsoft.com/workshop/c-frame.htm#/workshop/server/Default.asp (руководство и документация по ASP фирмы Microsoft);
• JSP. http://java.sun.com/products/jsp/ (главная страница Sun, посвященная JSP);
• Сервлеты. http://java.sun.com/products/servlet/ (главная страница Sun, посвященная сервлетам).
Применение XSLT с активными серверными страницами
Активные серверные страницы (Active Server Pages, ASP) выполняются на серверах Microsoft Windows NT или 2000, поэтому в ближайшем примере для преобразования planets.xml
при помощи planets.xsl
и возврата результата в виде документа HTML я воспользуюсь процессором Microsoft MSXML.
Это все то же преобразование, которое нам уже много раз встречалось, — создание HTML-таблицы данных о планетах — но на этот раз преобразование будет выполнено на web-сервере, который затем отправит его пользователю. В начале сценария ASP я установил тип содержимого MIME результирующего документа в « text/html
», поэтому он будет трактоваться как HTML:
Venus
.815
116.75
3716
.943
66.8
Earth
1
1
2107
1
128.4
В этом первом примере я создам таблицу стилей XSLT для форматирования файла planets.xml
и преобразования его в planets.fo
, использующую форматирующие объекты для задания шрифтов, стилей и цветов. Затем я воспользуюсь процессором fop и преобразую planets.fo
в файл planets.pdf
, который показан на рис. 11.1.

Рис. 11.1.Документ PDF, созданный при помощи форматирующих объектов
Как видно на рис. 11.1, в нашем первом примере я применил средства форматирования текста: установку шрифта, подчеркивание текста, выделение текста курсивом и даже установка цвета текста. (Хотя этого и не видно на рис. 11.1, заголовок «The Planets Table» выделен светло-голубым цветом.)
Первый шаг при создании документа на рис. 11.1 — применить таблицу стилей XSLT для преобразования planets.xml
в planets.fo
.
Преобразование в XSL-FO при помощи таблицы стилей XSLT
В этой главе я создам таблицу стилей для преобразования planets.xml
в planets.fo
. Я буду создавать таблицу шаг за шагом; для справки я приведу ее окончательный вид (листинг 11.2).
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:fo="http://www.w3.org/1999/XSL/Format"
version="1.0">
page-height="400mm" page-width="300mm"
margin-top="10mm" margin-bottom="10mm"
margin-left="20mm" margin-right="20mm">
margin-top="0mm" margin-bottom="10mm"
margin-left="0mm" margin-right="0mm"/>
line-height="48pt" font-family="Times" color="blue">
The Planets Table
line-height="48pt" font-family="Times"
font-style="italic">
Planet:
font-family="Times">
Mass
:
[Earth = 1]
font-family="Times">
Day
:
[Earth = 1]
font-family="Times">
Radius
:
miles
font-family="Times">
Density
:
[Earth = 1]
font-family="Times">
Distance
:
million miles
После применения этой таблицы стилей для преобразования planets.xsl
будет получен файл planets.fo
, который при помощи форматирующих объектов XSL-FO создает документ с видом, показанным на рис. 11.1. Вот как выглядит planets.fo
(листинг 11.3).
margin-left="20mm" margin-bottom="10mm"
margin-top="10mm" page-width="300mm"
page-height="400mm" master-name="page">
margin-bottom="10mm" margin-top="0mm"/>
line-height="48pt" font-size="36pt" font-weight="bold">
The Planets Table
line-height="48pt" font-size="28pt" font-weight="bold">
Planet:
Mercury
Mass
:
.0553
[Earth = 1]
:inline text-decoration="underline">
Day
:
58.65
[Earth = 1]
Radius
:
1516
miles
Density
:
.983
[Earth = 1]
Distance
:
43.4
million miles
font-size="28pt" font-weight="bold">
Planet:
Venus
Mass
:
.815
[Earth = 1]
Day
:
116.75
[Earth = 1]
Radius
:
3716
miles
Density
:
.943
[Earth = 1]
Distance
:
66.8
million miles
font-size="28pt" font-weight="bold">
Planet:
Earth
Mass
:
1
[Earth = 1]
Day
:
1
[Earth = 1]
Radius
:
2107
miles
Density
:
1
[Earth = 1]
Distance
:
128.4
million miles
Для того чтобы обработать planets.fo
и создать форматированный документ, я воспользуюсь процессором fop от Apache XML Project. Как утверждает Apache: «FOP — первое в мире средство форматирования, управляемое форматирующими объектами XSL. Приложение Java считывает дерево форматирующих объектов и затем преобразует его в документ PDF. Дерево форматирующих объектов может быть представлено в форме документа XML (полученного на выходе такого процессора XSLT, как XT или Xalan) или может быть передано в память как документ DOM или (в случае XT) событий SAX».
Я пользуюсь fop 0.17, — последней версией процессора на момент написания книги (похоже, что новые версии выходят практически ежемесячно). Процессор fop можно бесплатно загрузить с http://xml.apache.org/fop. Пакет загрузки fop включает три необходимых для работы файла JAR: fop.jar
, w3c.jar
и xerces.jar
, которые нужно включить в classpath
(добавьте правильные пути к этим файлам JAR в соответствии с требованиями вашей системы):
С:\>set classpath=.;fop.jar;xerces.jar;w3c.jar
Для преобразования planets.fo
в planets.pdf
служит класс fop org.apache.fop.apps.CommandLine
, которому в командной строке нужно передать имя входного документа, planets.fo
, и имя выходного, planets.pdf
:
C:\>java org.apache.fop.apps.CommandLine planets.fo planets.pdf
Вот и все; окончательный результат, planets.pdf
, в средстве просмотра Adobe Acrobat Reader вы увидите, если вернетесь к рис. 11.1.
Теперь вы видели, как выполняется процедура в общем; давайте перейдем к деталям и посмотрим, как создаются документы XSL-FO. Чтобы подробно все рассмотреть, я собираюсь взять за основу листинг 11.2, таблицу стилей XSLT, создающую planets.fo
.
СОЗДАНИЕ ДОКУМЕНТОВ XSL-FO С НУЛЯ
Заметьте, что не обязательно создавать таблицу стилей для преобразования документов XSL в форму XSL-FO. Я мог бы написать planets.fo так, как показано в листинге 11.3, с нуля, не прибегая к таблицам стилей XSLT. Но такой способ, как правило, годится только для коротких документов XML. Документы с форматированием XSL-FO становятся весьма длинными очень быстро (сравните длину planets.xml с planets.fo), поэтому для создания документов XSL-FO практически всегда применяйте таблицы стилей XSLT (хотя некоторые примеры в следующей главе достаточно коротки для того, чтобы написать их непосредственно при помощи XSL-FO).
Читать дальшеИнтервал:
Закладка: