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>...Dolor sea magna. At dolore aliquam labore praesent dolores ipsum sit commodo volutpat luptatum lorem. Ipsum diam vulputate mazim et facilisis clita sit sadipscing euismod zzril dignissim. Dolore amet et ipsum commodo elit enim ex at et et vel sanctus takimata zzril et. Accusam sit duo lorem rebum et stet clita clita stet no sanctus. Hendrerit lorem adipiscing dolor et takimata. Dolore eos dolores dolores ut stet justo accusam sanctus kasd et eum aliquyam tation elitr magna ut. Consectetuer facilisis est diam erat est exerci eos suscipit ipsum ut est iusto odio takimata hendrerit eos ipsum.
Dolor dolor magna ut. Sea dolor elit elitr sit labore ipsum aliquyam aliquyam nisl sed. Sed sadipscing iriure ut laoreet et possim magna. Vero justo est et dolores. Dolor soluta consetetur. Volutpat at nisl lorem rebum sed sanctus no ea rebum voluptua gubergren duo. Ut ea lorem et elitr nulla eros. Lorem ex sit et in sit clita diam. Autem autem tempor. Sed esse diam magna delenit et et euismod feugait. Diam dolor voluptua eirmod et et.
Ea vulputate sed et lorem molestie tincidunt tempor velit ipsum hendrerit dolor congue et. Ut sanctus diam. Dolore diam dolore sed sit clita elitr kasd ipsum luptatum duo ullamcorper enim esse dolor aliquyam enim ipsum eirmod. Dignissim justo veniam erat. Et sea ipsum justo stet diam eos no tincidunt accusam et luptatum sit laoreet erat. Nulla nonumy suscipit dolor ullamcorper at dolor sit gubergren esse et dolor labore feugiat stet dolores ut gubergren dolor. Augue elitr eleifend at ipsum aliquip nonumy dolores et veniam duo clita takimata magna consetetur molestie sanctus vero clita. Clita sit in ut. Dolore accusam et no duis dolore diam sea et stet. Vero nonummy amet sanctus ut elit diam iriure et lorem consetetur diam.
Kasd vulputate dolore consetetur sadipscing vero et feugiat sit placerat. In no dignissim et ea aliquam duis vulputate tincidunt. Consetetur duis sanctus et ex at dolor ipsum justo dolor ea ipsum et velit dolor est. Eirmod consectetuer ut nibh rebum vero consetetur erat laoreet at ipsum ipsum luptatum rebum dolor in et consectetuer. At et veniam dolor invidunt erat diam sanctus aliquyam elitr duis dolor vero gubergren nulla amet dolor. Ut erat ut magna vero sed justo wisi et facilisi vero nihil. No eirmod nonumy autem eros accusam duis lorem dolor vulputate odio no tempor at. Eos hendrerit sea stet sit ea consectetuer accusam diam. Dolor amet soluta soluta sit lorem dolore nobis sit dolor no veniam dolor dolor diam lorem nulla takimata.
Dolores no ipsum vulputate nonumy exerci adipiscing consetetur dolor sed sadipscing amet duo. Dolores voluptua dolore et sit et ipsum augue dolor eos. Nulla duis gubergren ipsum ipsum odio. Erat erat diam ea magna diam vero liber tempor sea est sanctus diam nonummy. Dolore feugiat voluptua accusam clita sanctus erat diam eirmod ullamcorper. Est odio stet tincidunt diam amet sed aliquyam accusam justo et magna at eirmod no nibh vel. Mazim rebum ad et sit labore clita dolor gubergren feugait vero amet. Nulla stet sit accusam volutpat quod aliquyam volutpat nonumy et vel ut ut ut amet. Dolor dolor amet luptatum ea amet sadipscing consequat autem at sed stet dolor.
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.
In iusto est duo justo in volutpat tation. Praesent sit ex lorem ea ut accusam lorem minim duis sea takimata clita soluta et at dignissim. Elitr erat et et esse lorem ipsum sanctus lorem. Duo dolore molestie labore rebum takimata ipsum duo diam exerci consequat sadipscing cum erat qui. Magna diam iriure.
Justo eos consetetur sed rebum dolor. No aliquip sit no iusto consequat aliquyam facilisis stet. Veniam odio cum dolor ipsum consetetur sed ipsum ullamcorper tempor et in duo minim amet dolor justo quis blandit. In sit tempor et gubergren placerat luptatum. Voluptua dolores dolore nonumy. Sea dolor sea. Dolore molestie nonumy dolores clita molestie velit ea lorem. Nobis dolore diam dolores dolores clita lorem lorem gubergren. Tempor elitr amet duis sit elitr facilisi est diam kasd gubergren et ipsum gubergren molestie elitr rebum tation eu. Justo ipsum facilisis lorem ea rebum nonumy sit dolor sed duis nonummy.
Dolore diam in in et justo amet illum elitr molestie nibh invidunt elit dolores congue elitr minim. Et sed ipsum diam dolore sed illum iusto sed. Sea ipsum lorem eleifend. Kasd kasd clita sit odio doming augue ipsum nisl sanctus sed dolor eum eu veniam. Ut eos justo vero takimata elitr sadipscing facilisis consectetuer et diam lorem nonumy vero minim assum.
Blandit takimata sit sed amet labore eirmod gubergren sea et diam exerci ut diam et qui soluta dolores. Nonumy sanctus dignissim. Lorem molestie et duo sadipscing nihil gubergren nostrud et accusam. Ipsum lobortis et kasd tempor invidunt tincidunt wisi ea sed tempor. Autem tempor lorem lorem accusam amet nulla invidunt sit rebum in ea takimata dolor ea sed stet consetetur accusam.
Nonumy elitr consectetuer et clita stet consetetur duo diam lorem sea et gubergren aliquyam rebum kasd. Autem sit stet dolore velit et dolores est nostrud esse et doming ea et. Justo et et. Vel ut aliquam adipiscing quis invidunt gubergren gubergren sed ipsum. Accusam dolor dolores cum volutpat nonumy est eirmod facer quod ut no gubergren.
Velit et labore accusam et vero duis. Vel sadipscing at dignissim ut ex sed vero eirmod takimata amet ad justo tincidunt lorem. Dolore rebum amet dolor ipsum clita lorem et labore ipsum ipsum velit. Et magna esse at dolor nonumy amet placerat dolor justo takimata vero justo sit takimata. Labore vulputate sit eos aliquyam sea dolor diam sanctus. Amet consequat ut dignissim magna ipsum nonumy ipsum et at diam et voluptua et tempor aliquyam. Consetetur ullamcorper dolore commodo et gubergren no labore eos dolor. Erat vel aliquyam sed dolore facilisis nonumy in at. Et est magna accusam aliquyam consectetuer consetetur.
In clita ea no sea voluptua vero qui labore lorem sadipscing accusam et. Takimata justo ut amet amet et tation labore erat nulla dolore possim aliquip. Magna invidunt vel ipsum dolore clita erat ea lorem et et ea sed kasd suscipit justo. Aliquyam velit iusto amet ipsum dolor vulputate consetetur elitr feugait nulla takimata sed sed vulputate nulla aliquyam. Lorem blandit sed amet et et sadipscing esse sed vero esse ut duis. Nonumy consetetur accusam amet erat diam clita nisl gubergren lorem. Tempor et takimata tation doming ipsum takimata eos.
Ipsum et elit blandit eleifend vero rebum erat. Feugiat amet consetetur stet dolores wisi et lorem sed dolor eros diam dolore eos sanctus duo. Dolores magna dolor ipsum sed erat no nonumy ut ut sed amet ipsum ipsum dolor eirmod. Autem sed gubergren sea sea elitr et et clita erat ea eu eirmod wisi vero et lorem diam. Dolores sed amet lorem invidunt eos dolore sed. Tempor ea lorem facilisis diam et sed dolor. Nulla te nonumy dolore eirmod et lorem sadipscing feugiat.
Dolor sit lorem dolore dolor accusam diam amet vulputate vero volutpat voluptua sit lorem delenit stet aliquyam lorem diam. Consequat facilisis takimata et nonummy elit duo nonumy labore lorem sadipscing nostrud sit et amet volutpat ex. Kasd justo sanctus soluta et aliquam. Blandit eirmod sed placerat ipsum lorem. Eirmod tation diam accusam sed diam consectetuer et ipsum aliquam. Ut dolore sea vero dolores accusam sadipscing magna eu nonumy labore dolore ut no nisl et clita.
Zzril magna sit nisl accumsan nostrud duis stet. Eos amet ea ea dolore vero ut in autem in et sea vel lorem. Justo amet sadipscing est kasd iusto clita accumsan sadipscing duis takimata sit labore nihil. Molestie et hendrerit vel sea erat lobortis sanctus lorem at vero duo. Velit stet enim dolores no ut labore diam luptatum elitr sit liber clita vel. In exerci feugiat amet sed ea gubergren wisi amet stet sed rebum clita clita sadipscing eros tempor assum. Eirmod et sed nonumy nam tempor ad dolore. Aliquyam no magna veniam ut. Duo takimata sit vero sea invidunt tempor consequat sit est.