Get a Free Trial

Take Website Screenshots with Node.js

DownloadTechnical Information
Node.js API
The diagnostics panel can help you debug your code!

The best way to put website screenshots and more into your Node.js application is by following these steps:

  1. Get your free Application Key and Secret.
  2. Download the free Node.js Library and try out the Demo Application.
  3. Find out the basics about how GrabzIt's API works by reading the below overview.

This library is server-side only. If you want to process captures with client-side JavaScript, you should use our client-side JavaScript API instead.

Node.js API Overview

To use the API you will first need to create the Client object, passing your application key and application secret from your GrabzIt account to the constructor.

var grabzit = require('grabzit');

var client = new grabzit("Sign in to view your Application Key", "Sign in to view your Application Secret");

Then use one of the image, DOCX, PDF, animation or table options to capture a URL or convert HTML.

// To take a image screenshot
client.url_to_image("https://www.tesla.com"); 	
// Or to take a PDF screenshot
client.url_to_pdf("https://www.tesla.com");
// Or to convert online videos into animated GIF's
client.url_to_animation("http://www.example.com/video.avi");
// Or to capture table(s)
client.url_to_table("https://www.tesla.com");
// To convert HTML into a image
client.html_to_image("<html><body><h1>Hello World!</h1></body></html>"); 	
// Or convert HTML into a PDF document
client.html_to_pdf("<html><body><h1>Hello World!</h1></body></html>");
// Or convert HTML into a CSV, XLSX or JSON document
client.html_to_table("<html><body><table><tr><th>Name</th><th>Age</th></tr>
    <tr><td>Tom</td><td>23</td></tr><tr><td>Nicola</td><td>26</td></tr>
    </table></body></html>");
// To convert HTML file into a image
client.file_to_image("example.html"); 	
// Or convert HTML file into a PDF document
client.file_to_pdf("example.html");
// Or convert HTML file into a CSV, XLSX or JSON document
client.file_to_table("tables.html");

Next the capture must be saved, to do this you must use either the save or save_to method, both of which pass in a function to handle any errors that have occured. The save method call below includes the URL of the handler that will process the callback from GrabzIt and save the screenshot or capture.

client.save("http://www.example.com/handler", function (error, id){
    if (error != null){
        throw error;
    }
}); 	
Always use the save_to method on localhost

The other option is to use the synchonous save_to method, which will force your application to wait while the screenshot is created so it should only be used were the save method cannot be used.

Once the screenshot is created it will be automatically saved to the file path provided. Note that the Node.js Library will only work on the server side as it requires server features in order to work properly.

client.save_to("images/result.jpg", function (error, id){
    //this callback is called once the capture is downloaded
    if (error != null){
        throw error;
    }
}); 	

More Options

This is only a overview of GrabzIt's Node.js API, there are many more options when creating screenshots, animated GIF's or converting HTML including; configuring the browser height, browser width, screenshot height, screenshot width, the delay before a screenshot is taken and the image format of the screenshot. For all these options and the ability to convert the web into PDF's, CSV's or Animated GIF's please see the Client documentation. There are also more advanced examples available.