We implemented the spacialized attribute fostyle to carry this information.
Because the browser just ignores this, you must be careful to structure it correctly for processing.
The proper structure is name: value; noting that the ":" after name is followed
by a space and the ";" between items is also followed by a space.
In some instances you may wish to pass through XSL FO attributes that are not
supported in HTML. This is an example, while the text in the HTML has a brown color
applied, we have applied a CMYK color for the PDF generation through the use of the
fostyle attribute. All fostyle attributes are applied
after HTML css and also after direct attributes and override those in the HTML. This
paragraph also has text-align justify in the HTML and font-stretch,
font-size-adjust and hyphenate in the PDF output. The fostyle attribute
is attached right in the HTML, just like style and uses the same
structure internally as style.
The code for the paragraph above looks like this:
<p style="color: brown; text-align:justify;"
fostyle="text-align-last: left;
font-stretch: wider;
font-size-adjust: 0.6;
hyphenate: true;
color: rgb-icc (255, 255, 0, #CMYK, .1, .2, .7, .5);">In some instances ...
Another common use for passing through custom elements is for properties that have specific meaning in a pagination situation like "keeps". There are several forms of keeps that can help you organize content so it is glued together as you like it.
The following are the most commonly used keeps:
keep-together.within-page: set to "always" and used to keep a block
of content always together in a single pagekeep-with-next.within-page: set to "always" and used to keep a
block of content glued to the next one always together in a single pagekeep-with-previous.within-page: set to "always" and used to keep a
block of content glued to the previous one always together in a single pagekeep-together.within-line: set to "always" and used to keep a span
of content glued always together in a single lineThe following shows some demonstrations of these capabilities.
This paragraph, the instructions and the following three para's of LoremIpsum
text are surrounded by a <div> with
keep-together.within-page as always, like
this:
<div fostyle="keep-together.within-page: always;">
<p>This paragraph, the instructions and the following five para's of LoremIpsum text are surrounded
by a <div> with "keep-together.within-page" as "always", like this:</p>...Et est takimata lorem sea gubergren duis ut amet invidunt et ipsum clita. Placerat dolore lorem amet ullamcorper dolore adipiscing consectetuer dolor ut kasd justo lorem iriure enim accusam voluptua dolor. Rebum sadipscing nulla justo gubergren lorem dolor amet. Duo nulla et hendrerit stet tempor sadipscing vel tincidunt duo dolore molestie nostrud sit ipsum iusto possim consequat. Dolor eirmod sed sed et dolore ut dolor dolor. Consetetur consetetur consequat. Ea invidunt ea amet veniam exerci et ipsum suscipit sed et aliquyam ea eum clita sadipscing elitr voluptua. Sea invidunt sea at. Dolore sit ea sanctus amet et feugiat amet rebum accusam enim dolor elitr et lorem amet erat. Sit sea nibh ea lorem dolor adipiscing aliquam et magna vel consetetur ut enim diam quis tempor consectetuer lobortis. Ut dolor accusam tation delenit.
Et dolor quod erat tincidunt et tempor nulla minim et et. Voluptua sed at rebum dolor dolore takimata no. Dolore vero clita voluptua. Consetetur sanctus in diam et stet et ad et dolores laoreet lorem et sit. Invidunt consetetur eos dolor vero et dolore placerat vero aliquyam dolores et voluptua ipsum voluptua. Iriure facilisis aliquip est kasd labore justo gubergren aliquyam eos.
Vero ea ullamcorper in amet sea ea ut duo at ea invidunt dolor lorem eirmod at illum clita dolore. Diam diam molestie voluptua diam sed stet et exerci clita rebum sanctus dolore dolor. Sadipscing dolor elitr wisi dolore nonumy amet dolores elit sanctus dolor erat delenit ipsum et iriure tation lorem. Hendrerit et et sanctus ea nostrud est no feugiat est no takimata mazim et consetetur voluptua eos consequat. Sit lorem accusam magna nulla kasd lorem nibh takimata ipsum aliquyam dolor amet. Ea gubergren ipsum sadipscing gubergren accusam quod aliquyam tation eu et volutpat sit dolor qui et ipsum nonumy soluta.
Duo labore takimata consequat sit erat ut consetetur lorem duis dolor dolore vero dolore et kasd gubergren sit. Sit tincidunt labore dolor feugait dolores. In gubergren euismod aliquip diam at sit amet dolore veniam kasd sadipscing dolor autem sanctus rebum nonummy. Dolor feugiat nihil lorem diam amet consetetur est placerat nonumy. Nisl amet dolore invidunt labore est sit ea nonumy velit diam sed labore dignissim invidunt ea. Lorem sit sed aliquyam velit at rebum accusam zzril dolor sanctus.
Eirmod erat dolor diam diam dolore eleifend molestie no. Assum elitr gubergren. Tempor et vero elit kasd kasd elitr duo nonummy veniam voluptua ut te sit amet magna sed. Duo eirmod duis eos sit aliquyam dolor ut at ut dolore justo tempor et. Dolor tempor nibh molestie est sed at et sadipscing dolor dolor. Eos kasd magna dolores amet rebum esse kasd duo labore amet eu sit takimata lorem magna amet labore. Est amet invidunt at aliquyam ipsum erat lorem vel labore. Aliquip ea sed odio diam elitr lorem sea accusam iriure stet. Tation lorem at sit consequat ea consetetur consetetur autem sed et sadipscing tempor nulla sanctus facilisis aliquyam hendrerit et. Dolore augue labore blandit magna ut iriure in sed gubergren sadipscing augue ut vero vero accusam. Diam aliquyam sed vero ipsum lorem.
Thus all of this content from the header through this paragraph is together on a single page.
A common practice in print documents is keeping together headings and some of the following lines of a paragraph so no heading is orphaned at bottom of a page and at least a few lines of text from any paragraph stay together.
What follows this are a series of headings and LoremIpsum paragraphs. The headings all have "keep-with-next.within-page" as "always" which will at least glue them to the paragraph. The paragraphs all have widows of "3" and orphans of "3" which will attempt to glue together at least three lines of paragraph at the bottom and top of any page. The LoremIpsum paragraphs are randomly generated on refresh of the page so you can test various layouts just by refresing and printing again.
Facilisis consetetur lorem dolore dolores. Consequat sit diam no invidunt sea sadipscing ad et. Stet diam et illum. Labore consetetur duo. Takimata vero iusto no duo dolor adipiscing consetetur. Kasd amet odio dolores sit takimata consetetur amet eirmod vulputate invidunt autem ad. Et ut facilisi invidunt amet lorem soluta dolor vel. Ea et te elitr diam et. Ea hendrerit sed magna iusto amet magna eirmod sit nobis.
Sit et vel luptatum amet no amet elit magna ea tempor commodo ea sit justo et laoreet consetetur quis. Dolor autem duis diam accusam. Consequat consetetur et eos ut volutpat wisi. Elitr accusam eirmod et eirmod sed clita et consequat justo no consetetur. Velit invidunt molestie invidunt ut ipsum amet et est eirmod takimata ipsum aliquam amet vero rebum. Et amet et aliquyam dolor laoreet soluta autem vero nibh sit sea sed ut.
Ea assum qui quod sit amet labore erat stet at accusam. Esse est et no erat nonumy amet consetetur sed aliquyam sed justo lobortis blandit. Et invidunt id erat eos commodo nibh stet ad velit amet rebum et sit lorem autem duo. Est elitr esse tempor sit ipsum nulla voluptua ipsum dolores justo quod tincidunt dolor est dolore congue. Duis sed lorem dolor liber takimata ipsum ipsum.
Diam amet diam no nonumy amet est duo est erat. Gubergren ut autem. Et amet eros justo rebum diam ut laoreet option. Et ex diam sit dolore facilisis sed dolor nonumy sed kasd eos sed augue nobis in. Sit nulla tempor dolor sed gubergren ut erat no nulla. Sit et nostrud ex accusam duo adipiscing labore erat congue ut diam elitr sed labore justo.
Dolores rebum sit est nibh. Ut ipsum voluptua clita eos ad eos velit takimata amet eirmod elit ut ea diam amet dolore nibh. Et kasd et facilisis et nonumy dolores in quis diam amet gubergren aliquyam et rebum. Stet elitr duis invidunt amet velit amet doming et takimata nulla dignissim quis. Dolore duis sanctus diam sed rebum autem et consetetur sed feugiat sed wisi et. Est ipsum ut eum ut accusam est invidunt amet erat ut at vulputate sanctus est dolore ipsum. Invidunt lobortis ex est dolor lorem ut sea ut iriure et lorem sanctus amet et lorem. Ut sed duo exerci et nam rebum ut dolore iriure ea.
Justo duo dolores consequat. Sea rebum ut stet feugiat hendrerit tempor sit dolor at magna blandit duo accusam sit et dolore sea. Et sed accusam elitr ut no hendrerit. At dolore adipiscing dolor et odio voluptua ipsum dolor clita tempor stet ea eos nonumy duo. Et consequat facilisis et justo consectetuer. Labore dolores qui enim magna magna sed no velit lorem imperdiet et takimata lorem dolor. Accusam lorem erat nonumy diam et duo laoreet imperdiet sanctus euismod sit elitr nostrud est eos dolor augue diam. Iriure sadipscing nonumy dolore dolor stet dolore accusam diam molestie sed lorem.
Diam erat dolore veniam et sanctus. Nibh kasd magna et feugiat ipsum sit nulla nonumy ea dolor ea takimata. Exerci et est sit et diam possim augue ea ea possim aliquyam in dolor. Dolor ut qui. Dolor diam tempor sadipscing invidunt et magna sea diam tempor nonumy.
Lorem diam clita voluptua quod amet voluptua illum option dignissim odio kasd dolore eleifend duo tincidunt sed facilisis nonumy. Hendrerit invidunt velit dolores voluptua sed sea sed amet liber dolore takimata erat ut sed aliquam tempor feugiat dolore. Dolor dolor ipsum sit eirmod stet tempor sit lorem aliquyam. Ipsum rebum sit lorem et in in invidunt et enim eleifend. Lorem sed accusam est ipsum vel. Et invidunt kasd sit et nisl exerci gubergren lorem facilisis. Velit labore aliquyam. Nonummy dolore odio labore sed et tempor ut nonumy dolor sea et ipsum justo. Iusto nostrud et amet et rebum nibh elitr dolore aliquyam lorem elitr. Sadipscing sed ipsum. Diam dolor nibh in dolore.
Sit accusam sea suscipit stet lorem. Et lorem et lorem nonummy takimata nostrud ipsum justo. Quis nulla assum clita diam enim dolor feugiat dolores duo esse amet. Aliquip aliquip tempor amet esse amet lorem consetetur accusam. Et ut tempor ut wisi erat stet ullamcorper ea. Rebum diam kasd clita.
Dolor et at magna erat ipsum takimata magna sed lorem amet dolore sea amet nisl nonumy dolor. Te lorem takimata lorem et clita nobis labore nonummy feugait voluptua et. Voluptua consetetur diam et amet consectetuer ipsum. Diam accusam luptatum consectetuer diam rebum. Ipsum eos elitr sanctus. Takimata laoreet sit adipiscing placerat mazim. Ea et nostrud sed ipsum sit iriure justo sit kasd consetetur gubergren eum erat. No autem feugiat dolor nonummy eum et at augue et eos sit dolor amet. Lorem aliquyam facilisis dolor aliquyam vero accusam nonumy amet eos volutpat. Sed nibh tempor sed nulla. Autem voluptua justo ut amet dolor vero odio.