跳至页脚内容
使用IRONPDF

Blazor 使用 IronPDF 在新标签页中打开 PDF:开发人员教程

在一个新的浏览器选项卡中打开PDF文档是Blazor网络应用程序的常见需求。 本教程演示了如何使用 IronPDF 生成 PDF 并使用 JavaScript 互操作将其显示在新标签页中,从而为用户提供无缝的文档查看体验。 此示例专注于Blazor Server版本。

先决条件设置

首先在Visual Studio 2022中创建一个新的Blazor Server项目。通过NuGet包管理器控制台安装IronPDF:

Install-Package IronPdf

在 Program.cs 中配置 IronPDF 许可证以启用全部功能:

License.LicenseKey = "YOUR-LICENSE-KEY";
License.LicenseKey = "YOUR-LICENSE-KEY";
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

理解挑战

Blazor Server应用程序无法直接从服务器上的C#代码操作浏览器选项卡。 Blazor 在新标签页中打开 PDF 的任务需要 JavaScript InterOp(JS 互操作)来连接服务器端 PDF 生成与客户端窗口管理。

IronPDF 使开发人员能够在服务器上生成高质量的 PDF 文档,然后可以使用 JavaScript 的 window.open() 功能显示这些文档。 这种方法意味着要解决网络应用程序中常见的客户端-服务器问题。

在Blazor网络应用程序中实现JavaScript函数

将此 JavaScript 代码添加到您的 _Host.cshtml 文件中,以处理 PDF 在新浏览器标签页中的显示。 这是负责客户端窗口管理的模块:

<script>
    window.openPdfInNewTab = function (pdfData, fileName) {
        // Convert base64 to blob
        const byteCharacters = atob(pdfData);
        const byteNumbers = new Array(byteCharacters.length);
        for (let i = 0; i < byteCharacters.length; i++) {
            byteNumbers[i] = byteCharacters.charCodeAt(i);
        }
        const byteArray = new Uint8Array(byteNumbers);
        // The type is 'application/pdf', not 'image/png' or 'image/jpg'
        const blob = new Blob([byteArray], { type: 'application/pdf' });
        // Create URL and open in new tab
        const blobUrl = URL.createObjectURL(blob);
        const newWindow = window.open(blobUrl, '_blank');
        if (newWindow) {
            newWindow.document.title = fileName || 'PDF Document';
        }
        // Clean up
        setTimeout(() => URL.revokeObjectURL(blobUrl), 100);
        return newWindow !== null;
    };
</script>
<script>
    window.openPdfInNewTab = function (pdfData, fileName) {
        // Convert base64 to blob
        const byteCharacters = atob(pdfData);
        const byteNumbers = new Array(byteCharacters.length);
        for (let i = 0; i < byteCharacters.length; i++) {
            byteNumbers[i] = byteCharacters.charCodeAt(i);
        }
        const byteArray = new Uint8Array(byteNumbers);
        // The type is 'application/pdf', not 'image/png' or 'image/jpg'
        const blob = new Blob([byteArray], { type: 'application/pdf' });
        // Create URL and open in new tab
        const blobUrl = URL.createObjectURL(blob);
        const newWindow = window.open(blobUrl, '_blank');
        if (newWindow) {
            newWindow.document.title = fileName || 'PDF Document';
        }
        // Clean up
        setTimeout(() => URL.revokeObjectURL(blobUrl), 100);
        return newWindow !== null;
    };
</script>
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

window.openPdfInNewTab JavaScript函数对于在服务器上打开新选项卡的问题至关重要。 它接受来自 Blazor 服务器的 PDF 数据作为 Base64 字符串,客户端代码将其转换为二进制 Blob 对象。

然后,该 blob 将用于创建一个临时 URL,最后将其传递给 window.open(blobUrl, '_blank'),以强制浏览器在新标签页中打开 PDF。

创建Blazor组件

创建一个新的Razor组件,生成PDF并在新选项卡中打开它们。 这作为解决方案的主要模板:

@page "/pdf-viewer"
@using IronPDF @inject IJSRuntime JS
<h3>Open PDF in New Tab</h3>
<div class="mb-3">
    <label>Enter URL:</label>
</div>
<button class="btn btn-primary" @onclick="GenerateAndOpenPdf"
        disabled="@isProcessing">
    @if (isProcessing)
    {
        <span>Generating PDF...</span>
    }
    else
    {
        <span>Generate and Open PDF</span>
    }
</button>
@if (!string.IsNullOrEmpty(errorMessage))
{
    <div class="alert alert-danger mt-3">@errorMessage</div>
}
@code {
    private string targetUrl = "https://ironpdf.com";
    private bool isProcessing = false;
    private string errorMessage = "";
    private async Task GenerateAndOpenPdf()
    {
        isProcessing = true;
        errorMessage = "";
        try
        {
            // Configure Chrome PDF renderer. Note the rendering details
            var renderer = new ChromePdfRenderer
            {
                RenderingOptions = new ChromePdfRenderOptions
                {
                    MarginTop = 10,
                    MarginBottom = 10,
                    MarginLeft = 10,
                    MarginRight = 10,
                    EnableJavaScript = true,
                    RenderDelay = 500
                }
            };
            // Generate PDF from URL
            var pdfDocument = await Task.Run(() =>
                renderer.RenderUrlAsPdf(targetUrl));
            // Convert to base64
            byte[] pdfBytes = pdfDocument.BinaryData;
            string base64Pdf = Convert.ToBase64String(pdfBytes);
            // Open in new tab via JS interop. We run this call to open the PDF
            bool success = await JS.InvokeAsync<bool>("openPdfInNewTab",
                base64Pdf, $"Document_{DateTime.Now:yyyyMMdd_HHmmss}.pdf");
            if (!success)
            {
                // Giving the user an understandable error is key
                errorMessage = "Pop-up blocked. Please allow pop-ups for this site.";
            }
        }
        catch (Exception ex)
        {
            errorMessage = $"Error: {ex.Message}";
        }
        finally
        {
            isProcessing = false;
        }
    }
}
@page "/pdf-viewer"
@using IronPDF @inject IJSRuntime JS
<h3>Open PDF in New Tab</h3>
<div class="mb-3">
    <label>Enter URL:</label>
</div>
<button class="btn btn-primary" @onclick="GenerateAndOpenPdf"
        disabled="@isProcessing">
    @if (isProcessing)
    {
        <span>Generating PDF...</span>
    }
    else
    {
        <span>Generate and Open PDF</span>
    }
</button>
@if (!string.IsNullOrEmpty(errorMessage))
{
    <div class="alert alert-danger mt-3">@errorMessage</div>
}
@code {
    private string targetUrl = "https://ironpdf.com";
    private bool isProcessing = false;
    private string errorMessage = "";
    private async Task GenerateAndOpenPdf()
    {
        isProcessing = true;
        errorMessage = "";
        try
        {
            // Configure Chrome PDF renderer. Note the rendering details
            var renderer = new ChromePdfRenderer
            {
                RenderingOptions = new ChromePdfRenderOptions
                {
                    MarginTop = 10,
                    MarginBottom = 10,
                    MarginLeft = 10,
                    MarginRight = 10,
                    EnableJavaScript = true,
                    RenderDelay = 500
                }
            };
            // Generate PDF from URL
            var pdfDocument = await Task.Run(() =>
                renderer.RenderUrlAsPdf(targetUrl));
            // Convert to base64
            byte[] pdfBytes = pdfDocument.BinaryData;
            string base64Pdf = Convert.ToBase64String(pdfBytes);
            // Open in new tab via JS interop. We run this call to open the PDF
            bool success = await JS.InvokeAsync<bool>("openPdfInNewTab",
                base64Pdf, $"Document_{DateTime.Now:yyyyMMdd_HHmmss}.pdf");
            if (!success)
            {
                // Giving the user an understandable error is key
                errorMessage = "Pop-up blocked. Please allow pop-ups for this site.";
            }
        }
        catch (Exception ex)
        {
            errorMessage = $"Error: {ex.Message}";
        }
        finally
        {
            isProcessing = false;
        }
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

此代码块定义了主要的交互页面。 Razor标记创建了一个简单的用户界面,包括URL输入字段和一个按钮。 C# @code 块负责处理逻辑:点击按钮后,它会使用 ChromePdfRenderer 实例从用户提供的 URL 生成 PDF。

然后,它将生成的 PDF 字节数组转换为 Base64 字符串,并使用 @inject IJSRuntime JS 调用 JavaScript 函数,为用户打开文档。

UI输出

!a href="/static-assets/pdf/blog/blazor-open-pdf-in-new-tab/blazor-open-pdf-in-new-tab-1.webp">Blazor Open PDF in new Tab with IronPDF:开发人员教程:图片 1 - 基本用户界面示例

在新标签中打开的PDF输出

!a href="/static-assets/pdf/blog/blazor-open-pdf-in-new-tab/blazor-open-pdf-in-new-tab-2.webp">Blazor Open PDF in new Tab with IronPDF:开发人员教程:图片 2 - 在新标签页中打开的第一个 PDF

处理动态HTML内容

要从动态内容而不是URL生成PDF,修改您的方法以使用RenderHtmlAsPdf

private async Task GenerateFromHtml()
{
    // Define CSS styles inside the HTML string for structure and appearance.
    string htmlContent = $@"
        <!DOCTYPE html>
        <html>
        <head>
            <style>
                body {{ font-family: Arial; padding: 20px; }}
                h1 {{ color: #2c3e50; }}
            </style>
        </head>
        <body>
            <h1>{documentTitle}</h1>
            <p>{documentContent}</p>
            <div>Generated: {DateTime.Now}</div>
        </body>
        </html>";
    var renderer = new ChromePdfRenderer();
    var pdfDocument = renderer.RenderHtmlAsPdf(htmlContent);
    byte[] pdfBytes = pdfDocument.BinaryData;
    await JS.InvokeVoidAsync("openPdfInNewTab",
        Convert.ToBase64String(pdfBytes), "dynamic.pdf");
}
private async Task GenerateFromHtml()
{
    // Define CSS styles inside the HTML string for structure and appearance.
    string htmlContent = $@"
        <!DOCTYPE html>
        <html>
        <head>
            <style>
                body {{ font-family: Arial; padding: 20px; }}
                h1 {{ color: #2c3e50; }}
            </style>
        </head>
        <body>
            <h1>{documentTitle}</h1>
            <p>{documentContent}</p>
            <div>Generated: {DateTime.Now}</div>
        </body>
        </html>";
    var renderer = new ChromePdfRenderer();
    var pdfDocument = renderer.RenderHtmlAsPdf(htmlContent);
    byte[] pdfBytes = pdfDocument.BinaryData;
    await JS.InvokeVoidAsync("openPdfInNewTab",
        Convert.ToBase64String(pdfBytes), "dynamic.pdf");
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

GenerateFromHtml 方法演示了 IronPDF 如何从动态生成的 HTML 标记而不是现有的 URL 生成 PDF。 它构造了一个完整的HTML字符串,包含标题、内容和动态数据。 动态内容生成的答案是 RenderHtmlAsPdf 方法。

更新后的Blazor Server UI

!a href="/static-assets/pdf/blog/blazor-open-pdf-in-new-tab/blazor-open-pdf-in-new-tab-3.webp">Blazor Open PDF in new Tab with IronPDF:开发人员教程:图片 3 - 服务器项目的更新示例 UI

在新浏览器标签中打开的PDF

!a href="/static-assets/pdf/blog/blazor-open-pdf-in-new-tab/blazor-open-pdf-in-new-tab-4.webp">Blazor Open PDF in new Tab with IronPDF:开发人员教程:图片 4 - 示例创建动态 PDF,然后在新标签页中打开。

处理常见问题

跨浏览器兼容性

不同的浏览器处理Blob URL的方式不同。 在Chrome、Firefox、Edge和Safari中测试您的实现,以确保一致的行为。

大文件

对于大型PDF文档,考虑实现服务端缓存以提高性能:

services.AddMemoryCache();
// Cache generated PDFs to avoid regeneration
services.AddMemoryCache();
// Cache generated PDFs to avoid regeneration
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

导航替代方案

除了JavaScript互操作,您还可以通过静态文件中间件提供PDF,并使用标准HTML锚标记作为替代导航选项:

<a href="/pdfs/document.pdf" target="_blank">Open PDF</a>
<a href="/pdfs/document.pdf" target="_blank">Open PDF</a>
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

这种方法适用于预生成的 PDF,但缺乏 JS InterOp 方法的动态生成功能。

最佳实践

1.错误处理:始终用 try-catch 块封装 PDF 生成,并在出现问题时向用户提供有意义的错误信息。 2.性能:使用异步/等待模式防止 PDF 生成过程中出现 UI 阻塞。

  1. 用户体验:在生成期间显示加载指示器,并优雅地处理弹出阻止程序场景。 4.DOM 操作:请记住,服务器上的 C# 不能直接操作客户端的 DOM; 这就是 JS InterOp 至关重要的原因。 您无需手动设置新窗口的高度或宽度,因为浏览器处理PDF查看器。 5.安全性:在生成 PDF 之前验证并清除用户输入

结论

IronPdf 强大的 PDF 生成功能与 Blazor 的 JavaScript InterOp 相结合,为在新浏览器标签页中打开 PDF 提供了强大的解决方案。 此方法使开发人员能够创建动态的、专业的PDF文档,这些文档无缝集成到由Microsoft的.NET技术构建的现代Blazor应用程序中。

准备好在您的Blazor项目中实现PDF功能了吗? 立即开始免费试用 IronPDF。 试用版包括无水印的完整功能和全面的支持,确保您的成功。

常见问题解答

如何使用Blazor在新标签中打开PDF?

您可以使用 Blazor 在新标签页中打开 PDF,方法是使用 IronPDF 生成 PDF,并利用 JavaScript 互操作将其显示在新标签页中。这种方法可确保用户在查看文档时获得流畅的体验。

什么是 Blazor 中的 JavaScript 互操作?

Blazor 中的 JavaScript 互操作允许 Blazor 应用程序从 .NET 代码中调用 JavaScript 函数,反之亦然。这对于在新标签页中打开PDF等任务非常有用,因为JavaScript可以处理特定于浏览器的操作。

为什么要使用 IronPDF 在 Blazor 中生成 PDF?

IronPDF 是在 Blazor 应用程序中生成 PDF 的高效工具。它提供了强大的功能,可实现无缝的 PDF 创建和操作,可轻松与 Blazor 的 JavaScript 互操作集成,以增强文档处理能力。

IronPDF 兼容 Blazor Server 吗?

是的,IronPDF 与 Blazor Server 完全兼容。它可用于生成和管理 PDF,然后使用 JavaScript 互操作在新标签页中打开 PDF。

在 Blazor 应用程序的新标签页中打开 PDF 有什么好处?

在新标签页中打开 PDF 可增强用户体验,让用户无需离开当前页面即可查看文档。这种方法由 IronPDF 和 JavaScript 互操作支持,可确保浏览会话更具互动性且不会中断。

Curtis Chau
技术作家

Curtis Chau 拥有卡尔顿大学的计算机科学学士学位,专注于前端开发,精通 Node.js、TypeScript、JavaScript 和 React。他热衷于打造直观且美观的用户界面,喜欢使用现代框架并创建结构良好、视觉吸引力强的手册。

除了开发之外,Curtis 对物联网 (IoT) 有浓厚的兴趣,探索将硬件和软件集成的新方法。在空闲时间,他喜欢玩游戏和构建 Discord 机器人,将他对技术的热爱与创造力相结合。