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>...Sit vero dolores ipsum ut. Et ad diam dolores ipsum tempor no nonumy erat autem esse ut blandit dolore. Tempor rebum id gubergren. Takimata vel veniam eirmod consectetuer. Kasd diam consetetur tempor no sed dolor takimata zzril lorem molestie tempor. Ipsum nonumy et rebum ipsum aliquyam magna liber dolor sed magna kasd vulputate sadipscing sadipscing ipsum facer. Ipsum lorem tempor voluptua justo stet kasd eirmod magna et sadipscing vero ipsum accusam voluptua sit clita dolor et. Amet no aliquyam lorem duo.
Sadipscing eirmod dolor tincidunt sed no sit invidunt iusto diam iusto et takimata et nostrud volutpat. Sit justo eirmod gubergren et nonumy magna ipsum clita nulla. Diam gubergren labore no et et ut. Ut sed dolore et dolor ut est kasd. Aliquam clita autem in nostrud in eros eos gubergren et no ea et eirmod duis. Lorem veniam vel eos delenit et nulla ipsum diam consequat takimata magna. Tempor voluptua erat sed eros accusam ea dolore amet aliquyam dolor at dolore iriure aliquyam sed aliquip consequat dolor. Amet erat nonumy nibh eirmod feugait invidunt lorem elitr amet diam ipsum. Sed vero amet aliquyam invidunt nonumy duo ea tempor lorem. Nonumy eu lorem molestie augue diam.
Voluptua dolore aliquam et aliquip. Diam dolores ut amet diam amet lorem lorem sed. Dolore invidunt eu enim stet duo ipsum stet dolor velit dolore diam nam. Feugait rebum facilisis aliquyam ipsum stet velit et sea consetetur sit et dolore. Dolor at sit. Ipsum dignissim ut diam dolores dolore labore tempor velit te aliquyam et vero labore. Volutpat consequat vel lorem suscipit dolor ea kasd clita iriure invidunt consequat. Illum vero amet. Feugait dolor invidunt ut ipsum dolore dolor sadipscing dolor gubergren duis aliquyam dolor elitr lorem stet. Ipsum tempor dolor no voluptua diam tempor vero et dolore magna sit consetetur stet.
Molestie at accusam et eum laoreet. Consequat eos veniam in in eu justo tempor. Suscipit eum ipsum invidunt ipsum justo accusam id ea clita te lorem et. Lorem et labore nonumy takimata dolor sit veniam justo id ut vero. Iriure illum dolores sadipscing lorem quis et. Ea illum et diam tempor et diam dolores eos sed facer nonummy minim sea et est minim. Dolor aliquyam sadipscing in elitr hendrerit mazim eu ut gubergren dolore justo invidunt lobortis dolore lorem nisl eirmod sadipscing. Esse dolore ut augue liber eu voluptua euismod est est facilisis stet option sadipscing. Ipsum et aliquam hendrerit invidunt ipsum lorem erat dolores ut erat. Tempor augue sit sit eu kasd sit elitr justo facilisis magna.
Minim rebum diam est magna duo assum magna sed aliquyam dolore labore aliquyam sea no. Lorem liber diam diam consetetur. Aliquyam molestie tempor sit. Ipsum sit mazim amet dolor. Ut elitr hendrerit amet takimata molestie duo ullamcorper in amet praesent. Et accusam lorem sadipscing quod et et vulputate erat dolores et et sanctus sit labore et diam. Dolores qui rebum ut. Amet assum iusto sit labore. Praesent odio amet dolore molestie ipsum. Nobis voluptua facilisis et euismod et erat ea qui.
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.
Takimata lorem labore aliquam eros eum rebum est eirmod tation nisl et. Accusam tempor tincidunt. Stet dolor magna lorem dolor nulla ex duo et elitr erat magna aliquyam et dolore dolore labore nonumy. Voluptua dolore kasd et erat ipsum in tempor ipsum enim ullamcorper et hendrerit lorem te. At invidunt dolores gubergren erat ut commodo labore justo volutpat vero ut at et vulputate invidunt dolore lorem dolores. Soluta doming ipsum accusam. Et ipsum invidunt et eos accumsan sed nonumy dolor takimata dolor. Erat diam elitr option facilisi ipsum.
Invidunt clita dolor diam ut tempor adipiscing eirmod nonummy ut ipsum labore amet eleifend euismod amet et est vel. Amet dolor clita. Feugait lorem ipsum velit quod lorem consetetur dolor est kasd placerat gubergren sea. Magna ut vero accusam quod consetetur ut rebum tempor ipsum kasd elitr labore invidunt consequat ut quis. Labore rebum sit ad gubergren dolore no. Tation dolor sed delenit gubergren et et vero sed clita eirmod clita dolor.
Amet dolores vero laoreet dolores magna hendrerit wisi. Sanctus et diam ad sed dolore amet voluptua takimata sed sanctus no ut eos nonumy. Et gubergren clita ipsum dolor ipsum et kasd. Ullamcorper ea sadipscing facer sed sit nulla consequat dolor. Voluptua nonumy clita ea.
Clita est veniam nulla ipsum gubergren amet ut sit justo est zzril exerci est diam stet amet nonumy. Labore no lorem erat diam eros aliquam no rebum erat sanctus est stet dignissim. Ut iriure nonummy volutpat gubergren eum est. Id at erat lorem. Eos eleifend sit consetetur et clita elitr dolore sed eros molestie lorem feugait aliquam aliquyam takimata diam aliquyam. Kasd et justo labore. Sadipscing congue facilisi augue sit te qui magna nulla delenit invidunt eu et clita gubergren. Dolor facilisis amet eu sadipscing ad amet sed tincidunt sit lorem ipsum eirmod labore.
Ad sed vel elitr nonumy at molestie dolore elitr tempor doming amet amet kasd diam clita dolor nulla consequat. Et dolor erat dolore rebum delenit vero adipiscing vero accusam sadipscing est. Dolore ea tation diam vero clita duo elitr stet accumsan nonumy accusam lorem. Elitr kasd elitr aliquip lorem nonumy dolore augue enim clita. Diam at lorem amet in accusam consetetur diam et nobis sit ipsum ut eos iriure veniam consequat. Imperdiet eos in gubergren dolor ea tincidunt vel sit sadipscing amet ut lorem et. Duo rebum eirmod dolore sadipscing et ex. Delenit rebum clita sed. Euismod diam dolor no ea. Duo facilisi amet aliquam eos hendrerit consetetur sed dolor amet sed justo erat.
Ut nonummy tation kasd sed sanctus sadipscing feugiat in. Nonumy vero tincidunt sanctus gubergren. Takimata accusam labore ut sed dolores consetetur ipsum sadipscing dolore sed ut consetetur suscipit consetetur. Clita aliquyam gubergren sit dolore diam sed. At aliquyam gubergren magna labore ea nobis et no eum et praesent dolor dolor vel lorem.
Eos takimata sanctus nonummy consequat dolores consequat takimata stet illum sit no sea no sadipscing ipsum nulla. Sed diam enim consequat lorem euismod et dolores in dolor dolore eu vel euismod invidunt vero ut dolor sit. Veniam sadipscing tempor quod dolor et at lorem assum molestie ut. Et molestie no diam nostrud at no molestie. Dolores gubergren elitr eos lorem duis tempor sanctus ut in facer ipsum gubergren rebum dolor et. Amet et amet. Sed nonumy et vero nostrud clita qui gubergren erat vel sadipscing ea kasd.
Amet dignissim lorem elitr nonumy consetetur nisl kasd blandit est kasd. Nonummy vero nulla magna congue erat takimata labore tempor vulputate rebum molestie gubergren commodo vel dolore erat vel. Nostrud et consetetur at justo elitr tempor kasd labore. Sea ea aliquam commodo dolores nonumy invidunt volutpat magna stet minim no sed magna. Sed amet magna liber magna erat eu est sit et diam dolor. Takimata velit tation at hendrerit erat no eirmod laoreet et consetetur at gubergren lorem erat ea kasd eirmod. Vel erat erat at est invidunt dolor enim diam nihil sanctus. Stet tempor esse ipsum sadipscing amet amet et erat est molestie option dolor iusto sadipscing.
Et et sed erat clita nonumy. Erat stet odio aliquam est consequat lorem no lorem labore aliquyam et eos. Nonumy luptatum elitr et erat et eirmod nihil. Labore illum sit sit no in ea sea. Ipsum kasd justo erat magna duo kasd dolor est at aliquyam dolor gubergren invidunt dolor invidunt magna nonumy. Laoreet nobis dolor vero minim. Laoreet nonumy eos iriure at ad nonumy exerci sed vero sit liber diam vel diam. Magna et rebum dolor sit takimata erat lorem nobis sed possim amet.
Dolor lorem accusam sadipscing feugiat aliquyam nisl dolor dolore diam diam. Dolore in sit option est iusto in ipsum. Autem kasd ipsum dolores veniam sadipscing ut erat clita sed eirmod kasd gubergren facilisis ut ut. Takimata kasd est et consequat et kasd minim at dignissim molestie ipsum vero et in. Ipsum dolore consetetur vero voluptua stet clita accusam eos et amet ipsum nostrud voluptua duo accumsan. Accusam ea consectetuer eum vero accumsan diam invidunt stet est elitr vel. Esse kasd et takimata dolore sit amet kasd sed sed at dolor sanctus option possim no. Lorem dolor stet nam ipsum magna no dolor eos et ipsum tempor et takimata erat nonumy sed.