spacer

Webref WebRef   Sitemap · Experts · Tools · Services · Newsletters · About i.com

home / experts / javascript / column89


Print Templates, Part I

Developer News
Microsoft Shows Off Silverlight 4, IE9 Plans
Metasploit Expands Vulnerability Test Framework
HyperCard Reborn?

Writing a Dynamic Print Template(2)

The event onLayoutComplete fires when the LayoutRect element is done rendering. We use the event property contentOverflow to tell whether the source is exhausted or the page is overflowed by a longer source.

The function onPageComplete() is called whenever the last page is overflowed by a longer source. This function is similar to the addFirstPage() function we showed on the previous page. We assemble a variable, newHTML, with one LayoutRect element within a DeviceRect element:

function onPageComplete() {
  if (event.contentOverflow) {
    document.all("layoutrect" +
      lastPage).onlayoutcomplete = null;
    newHTML  = "<IE:DEVICERECT
               ID='devicerect" + (lastPage + 1) +
               "' MEDIA='print' CLASS='masterstyle'>";
    newHTML += "<IE:LAYOUTRECT
               ID='layoutrect" + (lastPage + 1) +
               "' ONLAYOUTCOMPLETE='onPageComplete()'
               NEXTRECT='layoutrect" +
               (lastPage + 2) + "'
               CLASS='contentstyle'/>";
    newHTML += "</IE:DEVICERECT>";

    devicecontainer.insertAdjacentHTML("beforeEnd",
    newHTML);
    lastPage++;
  }
}

The trick here is how to assemble those attributes that are unique per page. These are ID (for both DeviceRect and LayoutRect) and NEXTRECT. They all consist of a fixed string concatenated to the page number. The current page number is lastPage + 1. The next page number is lastPage + 2. The DeviceRect element's ID is assembled by concatenating 'devicerect' and (lastPage + 1). The LayoutRect element's ID is assembled by 'layoutrect' and (lastPage + 1). The attribute NEXTRECT needs to reference the next page's LayoutRect element, so its value is 'layoutrect' + (lastPage + 2).

The variable lastPage is initialized to 1 before calling the first page, and is incremented after creating a new page.

Go ahead and try this dynamically-generated page. You can find a complete code listing on one of the next pages.

Next: Code listing of static print template

http://www.internet.com

internet.commediabistro.comJusttechjobs.comGraphics.com

Search:

WebMediaBrands Corporate Info

Legal Notices, Licensing, Permissions, Privacy Policy.
Advertise | Newsletters | Shopping | E-mail Offers | Freelance Jobs

webref The latest from WebReference.com Browse >
Rolling Out Your Own HTML Application Version Control · HTML 5: Client-side Storage · Working with Ajax Server Extensions
Sitemap · Experts · Tools · Services · Email a Colleague · Contact FREE Newsletters 
 The latest from internet.com
Wi-Fi Product Watch, November 2009 · Chip Market Recovering From '08 Collapse · Low-Cost Tools to Kickstart Your New Business


Produced by Yehuda Shiran and Tomer Shiran
All Rights Reserved. Legal Notices.
Created: July 30, 2001
Revised: July 30, 2001

URL: http://www.webreference.com/js/column89/7.html