This article demonstrates how to convert an HTML document or an HTML string to PDF with the help of Power Automate (Microsoft Flow).
We will take an invoice as a sample HTML document:
Using canvas based solutions (like the deprecated jsPDF.fromhtml function, not to be confused with the one from the accepted answer) is not an option for me since I want the text in the generated PDF to be pasteable, whereas canvas based solutions generate bitmap based PDFs. Convert HTML To PDF, generate PDF from html. In this blog, I will demonstrate how to generate a PDF file of your HTML page with CSS using JavaScript and Jquery. Why Join Become a member Login. Below we show how to convert web pages to PDF documents Step 1: Paste your web page URLs. Multiple web pages can be converted at a time. Paste each URL on a separate line. Step 2: Save PDF results. Click Convert HTML to PDF and wait until processing completes. Then press Download and save your PDF documents. They both utilize the wkhtmtopdf binary for converting html to pdf. Which uses the webkit engine for rendering the pages so it can also parse css style sheets. They provide easy to use seamless integration with C#. Rotativa can also generate directly PDFs from any Razor View. Instantly convert HTML files to PDF format with this free online converter. Nothing to install, no registration, no watermark. Click the UPLOAD FILES button and select up to 20 HTML files or ZIP archives containing HTML, images and stylesheets. Wait for the conversion process to finish and download files either one by one, using thumbnails,.
Use this link to download it.
Note
If you need custom fonts or multilingual support, review the documentation article describing how to work with various fonts and how to convert foreign characters correctly.
Our documents have to be stored somewhere. Power Automate (Microsoft Flow) has a lot of connectors for different systems. Here are just a few of them:
- SharePoint 
- Salesforce 
- Box 
- OneDrive 
- Google Drive 
- Dropbox 
- SFTP 
- File System 
You can store your files anywhere. In this example, we will store our documents in SharePoint. Our Flow will get an HTML file from a SharePoint document library, convert it to PDF and store generated file back to SharePoint document library.
This is how complete flow looks:
Here is step by step description for the flow.
Flow trigger
You can actually pick any trigger. For example, you can start Flow on file creation in a SharePoint document library. We use “Manually trigger a flow” trigger here to simplify the Flow.
Get file content
This action gets file content of the specified file from a SharePoint document library. You just specify SharePoint site URL and path to your file.
You can use any other connector to get files from your system.
Convert HTML to PDF
This is an action from Plumsail Documents connector.

Just put HTML file content from the output of the previous action and receive PDF file content as an output of this action. You can also use raw HTML string as a source HTML.
You can find more information about this action here.
Create file
Now you need to store the HTML file somewhere. In our example, we use “Create file” action from SharePoint connector to store the PDF document into SharePoint document library.
You can use any other connector to store PDF document into your system.
Hint

There is also Create HTML from template action available. You can use it in conjunction with Convert HTML to PDF action to create PDF documents from a template.
Generating a PDF from an HTML source is rarely an easy task. PDFs were designed with print needs in mind, which doesn’t always mesh well with the different forms and functions of web programs and applications. It can be a challenge for even the most seasoned developer to learn how to convert HTML to PDF in C#, without spending a lot of extra time fixing the post-conversion layout.
Luckily, you can harness the power of C# to make the process a little easier, and quickly produce great-looking PDFs from your web pages and applications.
Use the right tools
As a developer, you don’t need to spend a lot of time playing around with new APIs or learning different file formats to generate dynamic PDF files. There are several tool options to make the HTML-to-PDF conversion process easier by passing HTML to a function and generating the PDF file with formatting features intact. The quality of PDF generator tools can vary, particularly if your code involves tables or complex functions.

Design Elements to Consider
When you’re creating a PDF from HTML using C#, there are several design factors to keep in mind:
- Internal browser width and height
- CSS styles
- JavaScript files
- URLs of embedded images
- Headers and footers
- Dynamic data
- Page breaks
- Watermarks
- Page size of the generated PDF
- Orientation and margins of the generated PDF
These elements can all influence the final output of your PDF, so be sure to check their settings before beginning your HTML conversion project.

Creating a PDF from HTML

Most C# PDF generator tools can easily handle common coding elements, such as:
- HTML Strings and Files – Any HTML (HTML5) string or existing URL can be rendered into a PDF in a very efficient way. This includes referencing images, stylesheets, web fonts or even jQuery.
- CSS – Print and Screen CSS can both be rendered to PDF. Responsive CSS elements may be rendered at their smallest size, so Print CSS media types are strongly recommended.
- Javascript – Most C# PDF generator tools support Javascript, jQuery and AJAX, and is fully compliant with the Javascript standard.
This detailed tutorial includes several code examples for using C code to generate PDFs.
Html To Jpg
C# HTML to PDF PrintOptions Settings
The HtmlToPdf class contains a PrintOptions object that can help ensure the highest quality design rendering. For examples:
- DPI – sets the output DPI of the generated PDF
- FitToPaperWidth – sets the PDF content to fit the page width
- GrayScale – generates a black-and-white PDF
- PrintHtmlBackgrounds – includes background colors and images in the generated PDF
- CustomCssUrl – allows you to use a local file path or remote URL to apply a custom CSS style-sheet to the HTML before rendering it as a PDF.
- RenderDelay – ensures JavaScript, AJAX and other animations are fully rendered before generating the PDF
- Header and Footer – sets the header and footer content, respectively, for every PDF page
- Zoom – sets the zoom level to a specified percentage, allowing you to enlarge the rendering size of the HTML document.
Html To Pdf Generator Software
You may learn more about this comprehensive tutorial for a C# HTML to PDF settings.
Batch PDF Creation
Most developers have a need for creating multiple PDFs from HTML. You can set up batch PDF generation by creating an HTML template. This is an effective way to use C# String.Format to dynamically create PDF documents using a simple “mail-merge” methodology.
For more complex applications, such as those where a database query may be involved, a more sophisticated method is recommended. The Handlebars Templating Standard can be used to render a well-designed PDF layout when an unknown number of rows may be returned, such as an invoice or product inventory application.
Html To Pdf Generator Node Js
Need more help learning how to convert HTML to PDF in C? This tutorial also includes an easy downloadable C# PDF QuickStart Guide to help kickstart you first project using C code to generate PDF.
