C#でSelectPdfからIronPDFに移行する方法
SelectPdfからIronPdfに移行することで、PDF生成のワークフローが、時代遅れのレンダリングエンジンを搭載したWindows専用のソリューションから、CSS3とJavaScriptをフルサポートした最新のクロスプラットフォームライブラリに変わります。 このガイドでは、Linux、Docker、Azure Functions、およびSelectPdfがサポートしないその他のクラウドプラットフォームへのデプロイを可能にする、完全でステップバイステップの移行パスを提供します。
なぜSelectPdfからIronPDFへ移行するのか
SelectPdfを理解する
SelectPdfは、C#を使用してHTMLコンテンツをPDFに変換するために設計された商用ライブラリです。 このライブラリは、アプリケーション内にPDF生成機能をシームレスに統合することを必要とする開発者向けに作られています。 SelectPdfの強みはそのシンプルなAPIにあり、PDF生成の初心者にとって魅力的な選択肢となっています。
しかし、潜在的なユーザーは、その重大な制限を認識する必要があります。 クロスプラットフォーム機能を宣伝していますが、SelectPdfはWindows環境でのみ機能します。 これは、Azure FunctionsやDockerのようなコンテナなど、クラウドベースのデプロイソリューションを検討する際に大きな障壁となります。 さらに、無料版はかなり制限されており、積極的な透かしを適用する前に5ページまでしか使用できません。 SelectPdfは、時代遅れのBlinkフォークとWebKitベースのアーキテクチャを利用しているため、CSS Gridや高度なフレックスボックスのような最新のWeb技術との互換性に問題があります。
SelectPdfの重大な制限事項
| 問題 | インパクト | IronPDF ソリューション |
|---|---|---|
| Windowsのみ。 | Linux、Docker、Azure Functionsにはデプロイできません。 | クロスプラットフォームの完全サポート |
| 時代遅れのレンダリングエンジン。 | 最新のCSSではレイアウトが崩れる | 最新のChromium |
| 無料版は5ページまで。 | 5ページ以降の積極的な透かし | 豊富なトライアル |
| .NET10のサポートはありません。 | 将来を見据えた問題 | .NET 10をフルサポート |
| クラウド展開がブロックされました。 | AWS Lambda、Azure Functionsは使用できません。 | クラウドネイティブ |
SelectPdfとIronPdfの比較
| フィーチャー | セレクトPDF | IronPDF |
|---|---|---|
| プラットフォームサポート | Windowsのみ | 完全なクロスプラットフォーム、10以上のディストロ |
| 最新のWeb標準のサポート | 限定的(時代遅れのブリンク) | フルCSS3、モダンChromium |
| 最大無料版ページ数 | 5ページ | 柔軟性、制限なし |
| 価格について | 499ドルから | 透明で柔軟な価格設定 |
| .NET 10サポート。 | なし | サポート対象 |
| クラウド環境におけるデプロイメント | サポート対象外 | 完全サポート |
| CSSグリッド | 制限的 | サポート対象 |
| Flexbox(フレックスボックス | 制限的 | サポート対象 |
| CSS変数について | サポートされていません | サポート対象 |
| Docker。 | サポート対象外 | 公式画像 |
| Azureファンクション | サポート対象外 | サポート対象 |
| AWSラムダ | サポート対象外 | サポート対象 |
2025年、2026年まで.NET 10とC# 14の採用を計画しているチームにとって、SelectPdfは明確に.NET 10をサポートしていないため、将来的な問題が発生します。 IronPDFは最新のすべて for .NETバージョンをフルサポートしています。
始める前に
前提条件
- .NET環境: .NET Framework 4.6.2+ または.NET Core 3.1+ / .NET 5/6/7/8/9/10+
- NuGetアクセス: NuGetパッケージをインストールする機能
- IronPDFライセンス: IronPDFからライセンスキーを取得します。
NuGetパッケージの変更
# Remove SelectPdf
dotnet remove package Select.HtmlToPdf
# Install IronPDF
dotnet add package IronPdf
# Remove SelectPdf
dotnet remove package Select.HtmlToPdf
# Install IronPDF
dotnet add package IronPdf
ライセンス構成
// Add at application startup
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY";
// Add at application startup
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY";
' Add at application startup
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY"
完全な API リファレンス
名前空間の変更
// Before: SelectPdf
using SelectPdf;
// After: IronPDF
using IronPdf;
using IronPdf.Engines.Chrome;
// Before: SelectPdf
using SelectPdf;
// After: IronPDF
using IronPdf;
using IronPdf.Engines.Chrome;
' Before: SelectPdf
Imports SelectPdf
' After: IronPDF
Imports IronPdf
Imports IronPdf.Engines.Chrome
コア API マッピング
| セレクトPDF | IronPDF | ノート |
|---|---|---|
HtmlToPdf |
ChromePdfRenderer |
コアコンバータクラス |
converter.ConvertHtmlString(html) |
renderer.RenderHtmlAsPdf(html) |
HTML文字列の変換 |
converter.ConvertUrl(url) |
renderer.RenderUrlAsPdf(url) |
URL変換 |
doc.Save(path) |
pdf.SaveAs(path) |
ファイルに保存 |
doc.Close() |
不要 | IronPDFはクリーンアップを行います。 |
converter.Options.PdfPageSize |
renderer.RenderingOptions.PaperSize |
用紙サイズ |
converter.Options.PdfPageOrientation |
renderer.RenderingOptions.PaperOrientation |
オリエンテーション |
converter.Options.MarginTop |
renderer.RenderingOptions.MarginTop |
トップマージン |
converter.Options.MarginBottom |
renderer.RenderingOptions.MarginBottom |
下部の余白 |
converter.Options.MarginLeft |
renderer.RenderingOptions.MarginLeft |
左余白 |
converter.Options.MarginRight |
renderer.RenderingOptions.MarginRight |
右マージン |
PdfPageSize.A4 |
PdfPaperSize.A4 |
A4サイズ |
PdfPageOrientation.Portrait |
PdfPaperOrientation.Portrait |
ポートレート列挙 |
PdfPageOrientation.Landscape |
PdfPaperOrientation.Landscape |
ランドスケープ列挙 |
{page_number} |
{page} |
ページ番号プレースホルダ |
{total_pages} |
{total-pages} |
総ページ数 |
コード移行の例
例1: HTML文字列からPDFへの変換
翻訳前 (SelectPdf):
// NuGet: Install-Package Select.HtmlToPdf
using SelectPdf;
using System;
class Program
{
static void Main()
{
string htmlContent = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
HtmlToPdf converter = new HtmlToPdf();
PdfDocument doc = converter.ConvertHtmlString(htmlContent);
doc.Save("document.pdf");
doc.Close();
Console.WriteLine("PDF generated from HTML string");
}
}
// NuGet: Install-Package Select.HtmlToPdf
using SelectPdf;
using System;
class Program
{
static void Main()
{
string htmlContent = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
HtmlToPdf converter = new HtmlToPdf();
PdfDocument doc = converter.ConvertHtmlString(htmlContent);
doc.Save("document.pdf");
doc.Close();
Console.WriteLine("PDF generated from HTML string");
}
}
Imports SelectPdf
Imports System
Class Program
Shared Sub Main()
Dim htmlContent As String = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>"
Dim converter As New HtmlToPdf()
Dim doc As PdfDocument = converter.ConvertHtmlString(htmlContent)
doc.Save("document.pdf")
doc.Close()
Console.WriteLine("PDF generated from HTML string")
End Sub
End Class
翻訳後(IronPDF):。
// NuGet: Install-Package IronPdf
using IronPdf;
using System;
class Program
{
static void Main()
{
string htmlContent = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(htmlContent);
pdf.SaveAs("document.pdf");
Console.WriteLine("PDF generated from HTML string");
}
}
// NuGet: Install-Package IronPdf
using IronPdf;
using System;
class Program
{
static void Main()
{
string htmlContent = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(htmlContent);
pdf.SaveAs("document.pdf");
Console.WriteLine("PDF generated from HTML string");
}
}
Imports IronPdf
Imports System
Class Program
Shared Sub Main()
Dim htmlContent As String = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>"
Dim renderer = New ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf(htmlContent)
pdf.SaveAs("document.pdf")
Console.WriteLine("PDF generated from HTML string")
End Sub
End Class
この例は、コアAPIの違いを示しています。セレクトPDFはコンバーター クラスとして HtmlToPdf を使用し、ConvertHtmlString() を呼び出して PdfDocument を作成し、次に Save() と Close() を呼び出して永続化およびクリーンアップします。
IronPDF はChromePdfRenderer を RenderHtmlAsPdf() と組み合わせて使用し、SaveAs() で保存される PdfDocument を返します。 Close() 呼び出しは削除され、IronPDFがリソース管理を自動的に処理します。 包括的な例については、HTML to PDF documentationを参照してください。
例2: URLからPDFへの変換
翻訳前 (SelectPdf):
// NuGet: Install-Package Select.HtmlToPdf
using SelectPdf;
using System;
class Program
{
static void Main()
{
HtmlToPdf converter = new HtmlToPdf();
PdfDocument doc = converter.ConvertUrl("https://www.example.com");
doc.Save("output.pdf");
doc.Close();
Console.WriteLine("PDF created successfully");
}
}
// NuGet: Install-Package Select.HtmlToPdf
using SelectPdf;
using System;
class Program
{
static void Main()
{
HtmlToPdf converter = new HtmlToPdf();
PdfDocument doc = converter.ConvertUrl("https://www.example.com");
doc.Save("output.pdf");
doc.Close();
Console.WriteLine("PDF created successfully");
}
}
Imports SelectPdf
Imports System
Class Program
Shared Sub Main()
Dim converter As New HtmlToPdf()
Dim doc As PdfDocument = converter.ConvertUrl("https://www.example.com")
doc.Save("output.pdf")
doc.Close()
Console.WriteLine("PDF created successfully")
End Sub
End Class
翻訳後(IronPDF):。
// NuGet: Install-Package IronPdf
using IronPdf;
using System;
class Program
{
static void Main()
{
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf("https://www.example.com");
pdf.SaveAs("output.pdf");
Console.WriteLine("PDF created successfully");
}
}
// NuGet: Install-Package IronPdf
using IronPdf;
using System;
class Program
{
static void Main()
{
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf("https://www.example.com");
pdf.SaveAs("output.pdf");
Console.WriteLine("PDF created successfully");
}
}
Imports IronPdf
Imports System
Class Program
Shared Sub Main()
Dim renderer = New ChromePdfRenderer()
Dim pdf = renderer.RenderUrlAsPdf("https://www.example.com")
pdf.SaveAs("output.pdf")
Console.WriteLine("PDF created successfully")
End Sub
End Class
SelectPdf の ConvertUrl() メソッドは、IronPDF の RenderUrlAsPdf() に直接マップされます。 重要な違いはレンダリングエンジンです。SelectPdfは時代遅れのBlink/WebKitフォークを使用しており、最新のCSSと格闘していますが、IronPDFは最新の安定したChromiumを使用しており、CSS3とJavaScriptを完全にサポートしています。 詳しくは、チュートリアルをご覧ください。
例3: カスタムページの設定と余白
翻訳前 (SelectPdf):
// NuGet: Install-Package Select.HtmlToPdf
using SelectPdf;
using System;
class Program
{
static void Main()
{
HtmlToPdf converter = new HtmlToPdf();
converter.Options.PdfPageSize = PdfPageSize.A4;
converter.Options.PdfPageOrientation = PdfPageOrientation.Portrait;
converter.Options.MarginTop = 20;
converter.Options.MarginBottom = 20;
converter.Options.MarginLeft = 20;
converter.Options.MarginRight = 20;
string html = "<html><body><h1>Custom Page Settings</h1></body></html>";
PdfDocument doc = converter.ConvertHtmlString(html);
doc.Save("custom-settings.pdf");
doc.Close();
Console.WriteLine("PDF with custom settings created");
}
}
// NuGet: Install-Package Select.HtmlToPdf
using SelectPdf;
using System;
class Program
{
static void Main()
{
HtmlToPdf converter = new HtmlToPdf();
converter.Options.PdfPageSize = PdfPageSize.A4;
converter.Options.PdfPageOrientation = PdfPageOrientation.Portrait;
converter.Options.MarginTop = 20;
converter.Options.MarginBottom = 20;
converter.Options.MarginLeft = 20;
converter.Options.MarginRight = 20;
string html = "<html><body><h1>Custom Page Settings</h1></body></html>";
PdfDocument doc = converter.ConvertHtmlString(html);
doc.Save("custom-settings.pdf");
doc.Close();
Console.WriteLine("PDF with custom settings created");
}
}
Imports SelectPdf
Imports System
Module Program
Sub Main()
Dim converter As New HtmlToPdf()
converter.Options.PdfPageSize = PdfPageSize.A4
converter.Options.PdfPageOrientation = PdfPageOrientation.Portrait
converter.Options.MarginTop = 20
converter.Options.MarginBottom = 20
converter.Options.MarginLeft = 20
converter.Options.MarginRight = 20
Dim html As String = "<html><body><h1>Custom Page Settings</h1></body></html>"
Dim doc As PdfDocument = converter.ConvertHtmlString(html)
doc.Save("custom-settings.pdf")
doc.Close()
Console.WriteLine("PDF with custom settings created")
End Sub
End Module
翻訳後(IronPDF):。
// NuGet: Install-Package IronPdf
using IronPdf;
using IronPdf.Engines.Chrome;
using System;
class Program
{
static void Main()
{
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Portrait;
renderer.RenderingOptions.MarginTop = 20;
renderer.RenderingOptions.MarginBottom = 20;
renderer.RenderingOptions.MarginLeft = 20;
renderer.RenderingOptions.MarginRight = 20;
string html = "<html><body><h1>Custom Page Settings</h1></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("custom-settings.pdf");
Console.WriteLine("PDF with custom settings created");
}
}
// NuGet: Install-Package IronPdf
using IronPdf;
using IronPdf.Engines.Chrome;
using System;
class Program
{
static void Main()
{
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Portrait;
renderer.RenderingOptions.MarginTop = 20;
renderer.RenderingOptions.MarginBottom = 20;
renderer.RenderingOptions.MarginLeft = 20;
renderer.RenderingOptions.MarginRight = 20;
string html = "<html><body><h1>Custom Page Settings</h1></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("custom-settings.pdf");
Console.WriteLine("PDF with custom settings created");
}
}
Imports IronPdf
Imports IronPdf.Engines.Chrome
Imports System
Module Program
Sub Main()
Dim renderer As New ChromePdfRenderer()
renderer.RenderingOptions.PaperSize = PdfPaperSize.A4
renderer.RenderingOptions.PaperOrientation = PdfPaperOrientation.Portrait
renderer.RenderingOptions.MarginTop = 20
renderer.RenderingOptions.MarginBottom = 20
renderer.RenderingOptions.MarginLeft = 20
renderer.RenderingOptions.MarginRight = 20
Dim html As String = "<html><body><h1>Custom Page Settings</h1></body></html>"
Dim pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs("custom-settings.pdf")
Console.WriteLine("PDF with custom settings created")
End Sub
End Module
ページ設定のパターンはほぼ同じで、プロパティ名が変更されています:
converter.Options.PdfPageSize→renderer.RenderingOptions.PaperSizeconverter.Options.PdfPageOrientation→renderer.RenderingOptions.PaperOrientationPdfPageSize.A4→PdfPaperSize.A4PdfPageOrientation.Portrait→PdfPaperOrientation.Portrait
マージンプロパティは、同じ名前と単位を維持します。
Windowsだけの問題
SelectPdfのプラットフォームの制限
マーケティング上の主張にもかかわらず、SelectPdf は次のことを明示的にサポートしていません。
- Linux(ディストリビューションを問わず)
- macOS
- Dockerコンテナ
- Azure 関数
- AWSラムダ
- Google クラウド機能
- ARMベースのシステム
SelectPdfはWindows固有のライブラリに依存しているため、移植はできません。
プラットフォーム サポートの比較
|プラットフォーム|セレクトPDF|IronPDF| | ---------- | :---: | :---: ||Windows Server 2019+| ✅ | ✅ ||Windows 10/11| ✅ | ✅ ||Ubuntu 20.04+| ❌ | ✅ ||Debian 10 以上| ❌ | ✅ ||CentOS 7 以上| ❌ | ✅ ||アルパインリナックス| ❌ | ✅ ||Amazon Linux 2| ❌ | ✅ ||macOS 10.15+| ❌ | ✅ ||Azure App Service(Linux)| ❌ | ✅ ||Azure Functions| ❌ | ✅ ||AWSラムダ| ❌ | ✅ ||Docker (Linux)| ❌ | ✅ ||Kubernetes| ❌ | ✅ |
時代遅れのレンダリングエンジン
CSS機能サポートの比較
SelectPdfは時代遅れのBlink/WebKitフォークを使用しており、最新のWeb標準に追いついていません:
| CSS機能 | セレクトPDF | IronPDF |
|---|---|---|
| CSSグリッド | ⚠️ 一部/破損 | フル |
| フレックスボックス(基本) | ✅ | ✅ |
| Flexbox(ギャッププロパティ) | ❌ | ✅ |
| CSS変数 | ❌ | ✅ |
| CSS calc() | ⚠️ 有限会社 | ✅ |
| メディアプリント | ⚠️ 有限会社 | ✅ |
| フォントフェイス | ⚠️ 有限会社 | ✅ |
| ウェブフォント | ⚠️ 有限会社 | ✅ |
| SVG | ⚠️ 基本 | フル |
| CSSトランスフォーム | ⚠️ 有限会社 | ✅ |
| CSSアニメーション | ❌ | ✅ |
移行後の新機能
IronPDFに移行すると、SelectPdfでは提供できない機能が得られます:
クロスプラットフォームデプロイメント
// ✅IronPDF- Works everywhere
using IronPdf;
//Azure App Service(Linux)- WORKS
// Docker container - WORKS
//AWSラムダ- WORKS
// GitHub Actions on ubuntu-latest - WORKS
// macOS development - WORKS
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf("<h1>Hello</h1>");
pdf.SaveAs("output.pdf");
// ✅IronPDF- Works everywhere
using IronPdf;
//Azure App Service(Linux)- WORKS
// Docker container - WORKS
//AWSラムダ- WORKS
// GitHub Actions on ubuntu-latest - WORKS
// macOS development - WORKS
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf("<h1>Hello</h1>");
pdf.SaveAs("output.pdf");
Imports IronPdf
' ✅IronPDF- Works everywhere
'Azure App Service(Linux)- WORKS
' Docker container - WORKS
'AWSラムダ- WORKS
' GitHub Actions on ubuntu-latest - WORKS
' macOS development - WORKS
Dim renderer As New ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf("<h1>Hello</h1>")
pdf.SaveAs("output.pdf")
最新の CSS サポート
// ✅IronPDF- Uses latest stable Chromium
var renderer = new ChromePdfRenderer();
var html = @"
<style>
:root { --primary: #007bff; --gap: 20px; }
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--gap); }
</style>
<div class='grid'>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 1</div>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 2</div>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 3</div>
</div>";
var pdf = renderer.RenderHtmlAsPdf(html);
// All modern CSS features render correctly!
// ✅IronPDF- Uses latest stable Chromium
var renderer = new ChromePdfRenderer();
var html = @"
<style>
:root { --primary: #007bff; --gap: 20px; }
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--gap); }
</style>
<div class='grid'>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 1</div>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 2</div>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 3</div>
</div>";
var pdf = renderer.RenderHtmlAsPdf(html);
// All modern CSS features render correctly!
Imports IronPdf
' ✅IronPDF- Uses latest stable Chromium
Dim renderer As New ChromePdfRenderer()
Dim html As String = "
<style>
:root { --primary: #007bff; --gap: 20px; }
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--gap); }
</style>
<div class='grid'>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 1</div>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 2</div>
<div style='background: var(--primary); color: white; padding: 1rem;'>Item 3</div>
</div>"
Dim pdf = renderer.RenderHtmlAsPdf(html)
' All modern CSS features render correctly!
Close()は必要ありません
IronPDFはリソース管理を自動的に行います:
// Option 1: Let garbage collection handle it
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
// No Close() needed
// Option 2: Explicit disposal
using (var pdf = renderer.RenderHtmlAsPdf(html))
{
pdf.SaveAs("output.pdf");
}
// Option 1: Let garbage collection handle it
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
// No Close() needed
// Option 2: Explicit disposal
using (var pdf = renderer.RenderHtmlAsPdf(html))
{
pdf.SaveAs("output.pdf");
}
' Option 1: Let garbage collection handle it
Dim pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs("output.pdf")
' No Close() needed
' Option 2: Explicit disposal
Using pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs("output.pdf")
End Using
移行チェックリスト
移行前
- コードベース内のすべてのSelectPdfの使用を監査する
- マッピング用の電流コンバータオプションを文書化します
- ヘッダー/フッターの実装を特定する
- ページ番号プレースホルダーの構文を確認してください (
{page_number}→{page}) - ベースURLの処理パターンに注意してください
- ターゲット展開プラットフォームを確認する
- IronPDFからIronPDFライセンスキーを取得します
コードの更新
Select.HtmlToPdfNuGetパッケージを削除しますIronPdfNuGetパッケージをインストールします- 名前空間のインポートを更新します (
using SelectPdf;→using IronPdf;) HtmlToPdfをChromePdfRendererに置き換えますConvertHtmlString()をRenderHtmlAsPdf()に置き換えますConvertUrl()をRenderUrlAsPdf()に置き換えます- オプションプロパティ名を更新します (
Options.PdfPageSize→RenderingOptions.PaperSize) PdfPageSizeをPdfPaperSizeに変換しますPdfPageOrientationをPdfPaperOrientationに変換しますdoc.Save()をpdf.SaveAs()に置き換えます- すべての
doc.Close()呼び出しを削除します - ページ番号のプレースホルダーを修正しました (
{page_number}→{total_pages}→{total-pages}) - アプリケーションの起動時にライセンスの初期化を追加
移行後
- すべてのユニットテストを実行する
- CSSレンダリング(特にGrid/Flexbox)を検証する
- JavaScriptの実行をテストする
- ヘッダー/フッターのページ番号を確認する
- ターゲット プラットフォーム (Linux、Docker など) でテストする
- パフォーマンステスト
- PDF出力品質の比較
- CI/CDパイプラインを更新する
- クラウド展開をテストする(該当する場合)

