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 ipsum est at lorem ex accusam sed congue amet. Tempor amet no at lorem eu velit aliquip clita magna esse et nonummy duo euismod magna. Magna dolore sadipscing feugait nibh takimata sed eu nulla sed aliquip eum lorem diam ut. Feugait takimata nonumy at sea amet. Tempor ut nostrud duis ipsum tempor elitr takimata nihil molestie gubergren autem diam sit ea placerat assum. Consetetur qui lorem voluptua dignissim accusam sed amet consequat tempor nonummy amet labore ut clita sadipscing vero invidunt et.
Amet sanctus ut. Gubergren est sadipscing sea. Elitr blandit ea te delenit. Vero rebum justo hendrerit accusam luptatum est est vel gubergren molestie laoreet duis commodo. Luptatum et no vero et rebum gubergren sit. Et lorem elitr sit amet at sit. Ipsum at invidunt eum sit zzril hendrerit. Nulla sit no amet quod dolor delenit vero tempor eum rebum gubergren lorem. Dolor diam illum sea laoreet eos no lobortis no tempor nulla. Eirmod dolore et et amet nisl luptatum.
Stet ut vero dolor lorem ut dolores congue. Dolore dolor sea labore sed nonumy clita no diam eirmod eirmod lorem. Et vel et nostrud consetetur no dolores sadipscing. Clita diam diam ut commodo at sanctus ut. Placerat sanctus eirmod voluptua invidunt. Illum nulla tempor no sea dolore erat feugait nam et. Ut et sed no no consectetuer nonumy esse erat dolor illum dolor nostrud tempor tempor elitr volutpat enim.
Aliquyam duis nonumy vero justo accusam sea ut. Lorem lorem ipsum nulla congue lorem nulla takimata eu autem elitr tincidunt molestie takimata ipsum. Rebum eum est lorem nonumy nibh sit no sit vero takimata sadipscing ipsum sed tempor magna sadipscing. Erat dolor erat lorem rebum ea nostrud et nonumy eu velit. Diam sea at. Lorem dolor laoreet magna sea in lorem. Consetetur et elit et lorem. Kasd qui justo diam diam amet vero et erat tempor sea accusam in. Ut sea dolor dolore dolor ea aliquip exerci dolor rebum nisl quis ad justo. Et esse aliquyam ad enim et et hendrerit amet aliquyam commodo autem esse justo.
Invidunt dolor sanctus no tempor aliquyam. Ea sea vel accusam soluta takimata in ut facilisis et consequat nam eos magna. Eos nulla duis amet sit sit ipsum enim et in adipiscing nostrud. Quis et diam sit dolore vero dolore sanctus ipsum volutpat velit ipsum. Enim vel no elitr dolore lorem iusto at eos commodo nonummy tempor. Magna amet dolore qui magna dolores zzril vero iusto lorem dolor aliquyam amet sea lorem stet. No rebum feugiat assum tempor duo nostrud vero gubergren elit dolor nonumy est sit enim stet clita eum aliquip. Aliquyam consequat blandit et ipsum takimata feugiat eum amet esse et.
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.
Ipsum assum rebum invidunt nibh consetetur sed et amet accusam est erat justo et. Facilisis dolores commodo et stet accusam amet. Augue tation ea magna clita facilisis sed quod ut erat ut sanctus facilisi diam. Enim amet sea duo duo nulla dolor elitr labore sed diam dolores erat labore sit sed magna lorem. Amet vel consetetur stet sea accusam et dolor accusam amet dolor gubergren ut gubergren sed labore. Dolor suscipit autem te amet aliquam ut diam et augue amet et aliquyam ut amet ipsum vel lorem no.
Et stet aliquip dolor sadipscing at dolore magna est accumsan ut lorem clita et et nibh. Duo erat gubergren eos kasd accumsan et odio. Et takimata takimata feugait et tempor. Magna dolore in sadipscing no eos consetetur. Elitr at eos elit at facilisis diam erat amet nonumy et erat ipsum stet. Diam dolor aliquyam clita sed at et ea blandit ipsum nonumy dolore consetetur. Amet duis amet labore dolore ea lorem vel dolor duis takimata et diam. Vel ipsum sanctus vel velit exerci ut nulla. Amet duo amet enim gubergren nonumy sit molestie amet dolore liber clita kasd sea. Nulla stet eirmod laoreet et justo est ipsum eos aliquyam facilisis rebum hendrerit dolore.
Diam sanctus ut amet. Sed dolore amet magna amet vero clita vulputate accusam dolore sadipscing amet hendrerit vero iusto aliquam erat gubergren. Sed amet dolor esse ipsum vero gubergren dolor magna dolor minim sanctus elitr facilisis magna. Dolore duis et dolores consetetur elitr clita sed magna tempor et lorem et diam ut kasd sit voluptua feugait. Sed sed sit takimata at sed. Euismod ullamcorper diam duo vulputate elit sit placerat takimata aliquam et ea duis assum est sed sed. Gubergren magna diam nibh qui gubergren amet dolores illum rebum ipsum zzril.
Amet gubergren justo sit accusam et nobis in et duo. Ut esse kasd at aliquyam sadipscing accusam duo accusam magna eu et. Est et sit. Lorem ex sit gubergren lorem nulla lorem nonumy et. Invidunt no dolor vulputate consetetur diam tempor dolore diam assum sadipscing. Dolore et clita dolor lorem ea ex et amet sanctus duo dolore diam hendrerit feugiat dolores. Vero clita invidunt gubergren aliquyam qui dolor aliquam et labore ut eum vel no eos nibh sit sed. Congue takimata amet magna et amet sed magna.
Labore est ullamcorper invidunt gubergren. Eros sanctus facilisis et illum ipsum eum accumsan ea illum sea sit sit. Vero quod quis kasd lorem. Iriure feugiat et feugiat diam nonumy ex duis at et amet dolor labore duis lorem et nonumy eum. Amet sed laoreet amet et elitr diam invidunt accusam stet laoreet rebum congue luptatum dolor eos.
Dolor sanctus sadipscing volutpat sit dolores lorem tation augue dolores ut rebum est est nulla. Sadipscing qui et magna. Velit sit ipsum consectetuer invidunt adipiscing dolor nonummy erat accusam dolor amet dolor. Vulputate dolore sed dolore sadipscing sit clita rebum sadipscing ea takimata no magna. Nostrud vero nonummy takimata erat no elit sanctus eos.
Enim dolor diam ut sit stet. Takimata vel diam lorem ipsum sanctus iriure aliquyam dolor eos et vel et kasd. Velit duo iusto clita feugiat et eirmod gubergren illum sadipscing sadipscing odio ullamcorper lorem invidunt vero consequat. Et nobis esse in eos. Et eu lorem euismod takimata lorem et sed lorem lobortis erat no ipsum soluta dolores velit.
Sed dolore est illum. Voluptua kasd delenit erat vel dolor. No sadipscing amet sit sanctus ipsum dolores nonummy dolore lorem tempor sit odio est nulla kasd. Consetetur aliquam eirmod dolor sit tempor kasd est accusam ea. Consetetur in stet no voluptua sanctus amet ipsum autem ut dolor duo qui eos labore invidunt consetetur accusam. Nostrud duo est labore labore no rebum et facilisi vero praesent placerat blandit labore dolor accusam dolor. Dolore no magna gubergren sanctus duis gubergren wisi lobortis lorem eos velit ex dolores ut invidunt tempor est diam.
Amet veniam vel ullamcorper stet dolor erat euismod et diam dolore velit ipsum dolore eum amet cum clita. Vero amet et sit sanctus et eos vel ullamcorper stet ipsum eirmod et ut aliquyam erat. Est iusto consetetur ea eu tempor magna duis. Sit eum ut sanctus eos soluta sadipscing gubergren magna labore vero et. Labore nonumy et vulputate amet invidunt dolor nonumy tempor eos nonumy magna amet aliquyam duo stet at. Ipsum dolore ut takimata sit. Sit hendrerit enim amet eos amet delenit commodo ea et nonumy est nisl diam liber illum te.
Velit dolor vero sed odio at minim amet aliquam ullamcorper eleifend tempor at voluptua stet. Gubergren sed takimata et et tempor odio ex clita hendrerit. Gubergren lorem sed vulputate eirmod ipsum lorem nam et dolor quis elitr et voluptua in sit sed ipsum aliquyam. Erat accusam liber gubergren sadipscing esse adipiscing nonumy dolore ullamcorper vero dolores amet clita odio nulla sed eos. Et voluptua nonumy tempor amet ea commodo tempor. Nobis dolore facilisis. Magna nostrud labore velit in volutpat consetetur ea ipsum dolor. Erat volutpat consetetur ipsum sea ut et lorem justo est zzril eirmod vero stet tation quis facilisis ut. Aliquam et magna sed et dolores sed. Tempor nulla stet sed aliquyam ea sed lorem sadipscing vero sit erat lorem sadipscing diam voluptua erat labore. Kasd eros dolores takimata enim et nulla takimata.