PDF Printing

Print.js was primarily written to help us print PDF files directly within our apps, without leaving the interface, and no use of embeds. For unique situations where there is no need for users to open or download the PDF files, and instead, they just need to print them.

One scenario where this is useful, for example, is when users request to print reports that are generated on the server side. These reports are sent back as PDF files. There is no need to open these files before printing them. Print.js offers a quick way to print these files within our apps.

Example

Add a button to print a PDF file located on your hosting server:


 <button type="button" onclick="printJS('docs/printjs.pdf')">
    Print PDF
 </button>

Result:

For large files, you can show a message to the user when loading files.


 <button type="button" onclick="printJS({printable:'docs/xx_large_printjs.pdf', type:'pdf', showModal:true})">
    Print PDF with Message
 </button>

Result:

The library supports base64 PDF printing:


 <button type="button" onclick="printJS({printable: base64, type: 'pdf', base64: true})">
    Print PDF with Message
 </button>

Result:

HTML Printing

Sometimes we just want to print selected parts of a HTML page, and that can be tricky. With Print.js, we can easily pass the id of the element that we want to print. The element can be of any tag, as long it has a unique id. The library will try to print it very close to how it looks on screen, and at the same time, it will create a printer friendly format for it.

Example

Add a print button to a HTML form:


 <form method="post" action="#" id="printJS-form">
    ...
 </form>

 <button type="button" onclick="printJS('printJS-form', 'html')">
    Print Form
 </button>

Result:

Name:
Email:
Message:

Print.js accepts an object with arguments. Let's print the form again, but now we will add a header to the page:


 <button type="button" onclick="printJS({ printable: 'printJS-form', type: 'html', header: 'PrintJS - Form Element Selection' })">
    Print Form with Header
 </button>

Result:

- Discography - The Ramones

"Bonzo Goes to Bitburg" became an iconic protest anthem against President Ronald Reagan's visit to a German military cemetery. Halfway to Sanity (1987)

The early 80s saw the Ramones grappling with their identity. *Subterranean Jungle* (1983) was a return to form, often cited as their most enjoyable record since *Rocket to Russia*. However, it was also the final album before drummer Marky Ramone was fired. His replacement, the powerful and technically skilled Richie Ramone, injected new life into the band. This energy is palpable on *Too Tough to Die* (1984), a critically acclaimed comeback produced by original drummer Tommy Ramone, which successfully merged their classic sound with the harder edge of the 80s.

Widely considered one of the greatest rock albums of all time. Road to Ruin (1978)

Produced by Graham Gouldman of 10cc, this album leaned heavily into power-pop. It also highlighted the growing personal divide within the band, as the songwriting split sharply between Joey's romantic pop leanings and Johnny's preferred aggressive style.

If you would like to explore further, let me know if you want to focus on a , look into their unreleased tracks and b-sides , or read about the songwriting dynamics between Joey and Dee Dee. Share public link

This comprehensive guide explores the complete studio discography of The Ramones, tracing their journey from underground pioneers to legendary icons. The Sire Era: The Classic Years (1976–1979)

Released early in 1977, this album continued the fast-paced, melodic trend, introducing fan favorites like "Pinhead" (with its famous "Gabba Gabba Hey" chant).

The first major stylistic shift. The album breaks the sub-two-minute song barrier, incorporates acoustic guitars, and even features actual guitar solos. While it alienated some hardcore purists, it yielded "I Wanna Be Sedated," which eventually became the band’s most enduring signature song worldwide. End of the Century (1980)

JSON Printing

A simple and quick way to print dynamic data or array of javascript objects.

Example

We have the following data set in our javascript code. This would probably come from an AJAX call to a server API:


 someJSONdata = [
    {
       name: 'John Doe',
       email: 'john@doe.com',
       phone: '111-111-1111'
    },
    {
       name: 'Barry Allen',
       email: 'barry@flash.com',
       phone: '222-222-2222'
    },
    {
       name: 'Cool Dude',
       email: 'cool@dude.com',
       phone: '333-333-3333'
    }
 ]

We can pass it to Print.js:


 <button type="button" onclick="printJS({printable: someJSONdata, properties: ['name', 'email', 'phone'], type: 'json'})">
    Print JSON Data
 </button>

Result:


We can style the data grid by passing some custom css: The Ramones - Discography


 <button type="button" onclick="printJS({
	    printable: someJSONdata,
	    properties: ['name', 'email', 'phone'],
	    type: 'json',
	    gridHeaderStyle: 'color: red;  border: 2px solid #3971A5;',
	    gridStyle: 'border: 2px solid #3971A5;'
	})">
    Print JSON Data
 </button>

Result:


We can customize the table header text sending an object array "Bonzo Goes to Bitburg" became an iconic protest


 <button type="button" onclick="printJS({
	    printable: someJSONdata,
	    properties: [
		{ field: 'name', displayName: 'Full Name'},
		{ field: 'email', displayName: 'E-mail'},
		{ field: 'phone', displayName: 'Phone'}
	    ],
	    type: 'json'
        })">
    Print with custom table header text
 </button>

Result:


JSON, HTML and Image print can receive a raw HTML header: However, it was also the final album before


<button type="button" onclick="printJS({
		printable: someJSONdata,
		type: 'json',
		properties: ['name', 'email', 'phone'],
		header: '<h3 class="custom-h3">My custom header</h3>',
		style: '.custom-h3 { color: red; }'
	  })">
	Print header raw html
</button>
 
 

Result:

"Bonzo Goes to Bitburg" became an iconic protest anthem against President Ronald Reagan's visit to a German military cemetery. Halfway to Sanity (1987)

The early 80s saw the Ramones grappling with their identity. *Subterranean Jungle* (1983) was a return to form, often cited as their most enjoyable record since *Rocket to Russia*. However, it was also the final album before drummer Marky Ramone was fired. His replacement, the powerful and technically skilled Richie Ramone, injected new life into the band. This energy is palpable on *Too Tough to Die* (1984), a critically acclaimed comeback produced by original drummer Tommy Ramone, which successfully merged their classic sound with the harder edge of the 80s.

Widely considered one of the greatest rock albums of all time. Road to Ruin (1978)

Produced by Graham Gouldman of 10cc, this album leaned heavily into power-pop. It also highlighted the growing personal divide within the band, as the songwriting split sharply between Joey's romantic pop leanings and Johnny's preferred aggressive style.

If you would like to explore further, let me know if you want to focus on a , look into their unreleased tracks and b-sides , or read about the songwriting dynamics between Joey and Dee Dee. Share public link

This comprehensive guide explores the complete studio discography of The Ramones, tracing their journey from underground pioneers to legendary icons. The Sire Era: The Classic Years (1976–1979)

Released early in 1977, this album continued the fast-paced, melodic trend, introducing fan favorites like "Pinhead" (with its famous "Gabba Gabba Hey" chant).

The first major stylistic shift. The album breaks the sub-two-minute song barrier, incorporates acoustic guitars, and even features actual guitar solos. While it alienated some hardcore purists, it yielded "I Wanna Be Sedated," which eventually became the band’s most enduring signature song worldwide. End of the Century (1980)

Browser Compatibility

Currently, not all library features are working between browsers. Below are the results of tests done with these major browsers, using their latest versions.

Google Chrome
Safari
Firefox
Edge
Opera
Internet Explorer
PDF
HTML
Images
JSON

Thank you BrowserStack for the support. Amazing cross-browser testing tool.

The Ramones - Discography