You can insert page breaks in PDF using the page-break-before:always and page-break-after:always CSS attributes in HTML elements styles. The page-break-before:always attribute will force a page break right before the position in PDF page where the element would be normally rendered and the page-break-after:always will force a page break right after the position in PDF page where the element would be normally rendered.
using System;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Hosting;
// Use EVO PDF Namespace
using EvoPdf.Chromium;
namespace EvoPdf_Chromium_AspNetDemo.Controllers.HTML_to_PDF
{
public class Insert_Page_BreaksController : Controller
{
private readonly IWebHostEnvironment m_hostingEnvironment;
public Insert_Page_BreaksController(IWebHostEnvironment hostingEnvironment)
{
m_hostingEnvironment = hostingEnvironment;
}
// GET: Insert_Page_Breaks
public ActionResult Index()
{
SetCurrentViewData();
return View();
}
[HttpPost]
public ActionResult ConvertHtmlToPdf(IFormCollection collection)
{
// Create a HTML to PDF converter object with default settings
HtmlToPdfConverter htmlToPdfConverter = new HtmlToPdfConverter();
// Set license key received after purchase to use the converter in licensed mode
// Leave it not set to use the converter in demo mode
htmlToPdfConverter.LicenseKey = "4W9+bn19bn5ue2B+bn1/YH98YHd3d3c=";
byte[] outPdfBuffer = null;
if (collection["HtmlPageSource"] == "convertHtmlRadioButton")
{
string htmlWithForm = collection["htmlStringTextBox"];
string baseUrl = collection["baseUrlTextBox"];
// Convert the HTML string with page-break-before:always and page-break-after:always styles to a PDF document in a memory buffer
outPdfBuffer = htmlToPdfConverter.ConvertHtml(htmlWithForm, baseUrl);
}
else
{
string url = collection["urlTextBox"];
// Convert the HTML page with page-break-before:always and page-break-after:always styles to a PDF document in a memory buffer
outPdfBuffer = htmlToPdfConverter.ConvertUrl(url);
}
// Send the PDF file to browser
FileResult fileResult = new FileContentResult(outPdfBuffer, "application/pdf");
fileResult.FileDownloadName = "Insert_Page_Breaks.pdf";
return fileResult;
}
private void SetCurrentViewData()
{
ViewData["ContentRootPath"] = m_hostingEnvironment.ContentRootPath + "/wwwroot";
HttpRequest request = ControllerContext.HttpContext.Request;
UriBuilder uriBuilder = new UriBuilder();
uriBuilder.Scheme = request.Scheme;
uriBuilder.Host = request.Host.Host;
if (request.Host.Port != null)
uriBuilder.Port = (int)request.Host.Port;
uriBuilder.Path = request.PathBase.ToString() + request.Path.ToString();
uriBuilder.Query = request.QueryString.ToString();
ViewData["CurrentPageUrl"] = uriBuilder.Uri.AbsoluteUri;
}
}
}
<!DOCTYPE html>
<html>
<head>
<title>Insert Page Breaks Before and After HTML Elements Using CSS</title>
</head>
<body style="width: 1010px; font-family: 'Times New Roman'; font-size: 20px; margin: 5px">
<div style="width: 100%; height: 500px; background-color: aliceblue; border: 2px solid gray; text-align: center">
<div style="width: 100%; height: 200px"></div>
A block <b>without any page break</b> style<br />
<br />
[ Follows a block with <i>page-break-before : always</i> and <i>page-break-after : always</i> styles ]
</div>
<div style="page-break-before: always; page-break-after: always; width: 100%; height: 500px; background-color: gainsboro; border: 2px solid gray; text-align: center">
<div style="width: 100%; height: 200px"></div>
A block with <b>page-break-before : always</b> and <b>page-break-after : always</b> styles<br />
<br />
<b>This block will be always rendered alone in a PDF page</b><br />
<br />
[ Follows a block with <i>page-break-after : always</i> style ]
</div>
<div style="page-break-after: always; width: 100%; height: 500px; background-color: beige; border: 2px solid gray; text-align: center">
<div style="width: 100%; height: 200px"></div>
A block with <b>page-break-after : always</b> style<br />
<br />
<b>Nothing will be rendered after this block in PDF page</b>
<br />
<br />
[ Follows a block <i>without any page break</i> style ]
</div>
<div style="width: 100%; height: 500px; background-color: aliceblue; border: 2px solid gray; text-align: center">
<div style="width: 100%; height: 200px"></div>
A block <b>without any page break</b> style<br />
<br />
[ Follows a block with <i>page-break-before : always</i> style ]
</div>
<div style="page-break-before: always; width: 100%; height: 500px; background-color: lightgray; border: 2px solid gray; text-align: center">
<div style="width: 100%; height: 200px"></div>
A block with <b>page-break-before : always</b> style<br />
<br />
<b>This block will always be rendered at the top of a PDF page</b>
</div>
</body>
</html>