Saltar al pie de página
GUíAS DE MIGRACIóN

Cómo migrar de ABCpdf for .NET a IronPDF

Cambiar de ABCpdf para .NET aIronPDFes una actualización estratégica para los equipos de desarrollo que buscan licencias simplificadas, documentación moderna y soporte nativo multiplataforma. Esta guía completa ofrece una ruta de migración paso a paso, completa con asignaciones de API y ejemplos de conversión de código de escenarios del mundo real.

Ya sea que esté trabajando con .NET Framework 4.6.2 o apuntando a .NET 9 y posteriores hasta 2026, esta guía de migración de ABCpdf garantiza una transición fácil al motor de renderizado basado en Chrome de IronPDF.

¿Por qué considerar una migración a ABCpdf?

ABCpdf de WebSupergoo ha sido una biblioteca de PDF .NET capaz durante años. Sin embargo, varios factores hacen deIronPDFuna alternativa atractiva para los equipos de desarrollo modernos que planifican proyectos para 2025 y 2026.

Complejidad de las licencias

ABCpdf utiliza un modelo de licencia por niveles que puede resultar confuso de manejar. El precio comienza en $349 pero aumenta según las características, las implementaciones del servidor y los casos de uso. Muchos desarrolladores señalan que este laberinto de licencias supone una importante carga administrativa a la hora de presupuestar sus proyectos.

Arquitectura Windows-First

Aunque ABCpdf ha añadido soporte multiplataforma, su diseño histórico centrado en Windows aflora ocasionalmente en los flujos de trabajo. Los desarrolladores que se dirijan a contenedores Linux, entornos Docker o configuraciones de desarrollo macOS pueden encontrarse con fricciones no previstas durante la planificación del proyecto.

Estilo de la documentación

La documentación de ABCpdf, aunque completa, sigue un estilo antiguo que puede resultar anticuado en comparación con los estándares de documentación de API modernos. Los nuevos usuarios suelen tener dificultades para encontrar los ejemplos exactos que necesitan, sobre todo cuando trabajan con las versiones más recientes de .NET.

Sobrecarga de configuración del motor

ABCpdf requiere la selección explícita del motor (Gecko, Trident o Chrome) y la gestión manual de recursos con llamadas a Clear(). Esto añade código repetitivo a cada operación PDF que los desarrolladores modernos preferirían evitar.

IronPDFfrente a ABCpdf: Comparación de características

La siguiente tabla comparativa destaca las principales diferencias entre las dos bibliotecas PDF .NET:

Característica ABCpdf para .NET IronPDF
Motor de renderizado Gecko/Trident/Chrome (configurable) Chromium completo (CSS3, JavaScript)
Traducción multiplataforma Añadido más tarde, Windows-first Nativo Windows, Linux, macOS, Docker
Modelo de licencia Precios escalonados complejos a partir de 349 Precios sencillos y transparentes
Soporte .NET enfoque en .NET Framework De .NET Framework 4.6.2 a .NET 9+
Gestión de recursos Se requiere doc.Clear()manual IDisposable con declaraciones using
Configuración de licencias A menudo se utiliza el registro Clave de licencia basada en código simple
Documentación Estilo anticuado Documentos modernos con numerosos ejemplos

Antes de iniciar la migración

Prerrequisitos

Asegúrese de que su entorno de desarrollo cumple estos requisitos:

  • .NET Framework 4.6.2+ o .NET Core 3.1+ / .NET 5-9
  • Visual Studio 2019+ o JetBrains Rider
  • Acceso al gestor de paquetes NuGet
  • Llave de licencia de IronPDF (prueba gratuita disponible)

Encontrar todas las referencias ABCpdf

Ejecute estos comandos en su directorio de soluciones para localizar todos los archivos que utilizan ABCpdf para .NET:

grep -r "using WebSupergoo" --include="*.cs" .
grep -r "ABCpdf" --include="*.csproj" .
grep -r "using WebSupergoo" --include="*.cs" .
grep -r "ABCpdf" --include="*.csproj" .
SHELL

Esta auditoría identifica todos los archivos que requieren modificación, garantizando una cobertura completa de la migración.

Cambios importantes que hay que anticipar

Comprender las diferencias arquitectónicas entre ABCpdf para .NETeIronPDFevita sorpresas durante la migración:

Categoría Comportamiento de ABCpdf Comportamiento de IronPDF Acción de migración
Modelo de objeto la clase Doc es central ChromePdfRenderer + PdfDocument Separar el renderizado del documento
Limpieza de recursos Manual doc.Clear() Patrón IDisposable Utilice declaraciones using
Selección de motores doc.HtmlOptions.Engine = EngineType.Chrome Chrome integrado Eliminar la configuración del motor
Indexación de páginas basado en 1 (doc.Page = 1) basado en 0 (pdf.Pages[0]) Ajustar las referencias del índice
Coordenadas Basado en puntos con doc.Rect Márgenes basados en CSS Utilizar CSS o RenderingOptions

Inicio rápido: migración en 5 minutos

Paso 1: Actualizar paquetes NuGet

# Remove ABCpdf
dotnet remove package ABCpdf

# Install IronPDF
dotnet add package IronPdf
# Remove ABCpdf
dotnet remove package ABCpdf

# Install IronPDF
dotnet add package IronPdf
SHELL

Paso 2: Configure su clave de licencia

Añada esto al inicio de la aplicación, antes de cualquier operación IronPDF:

// Add at application startup (Program.cs or Startup.cs)
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY";
// Add at application startup (Program.cs or Startup.cs)
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY";
$vbLabelText   $csharpLabel

Paso 3: Buscar y reemplazar globalmente

Actualice todas las referencias a espacios de nombres en su código base:

Visite Sustituir por
utilizando WebSupergoo.ABCpdf13; <código>usando IronPDF;`
utilizando WebSupergoo.ABCpdf13.Objects; <código>usando IronPDF;`
usando WebSupergoo.ABCpdf12; <código>usando IronPDF;`
utilizando WebSupergoo.ABCpdf11; <código>usando IronPDF;`

Referencia completa de la API

Métodos de creación de documentos

La siguiente tabla relaciona los métodos de ABCpdf para .NETcon sus equivalentes en IronPDF:

Método ABCpdf Método IronPDF Notas
nuevo Doc() <código>new ChromePdfRenderer()` El renderizador crea PDF
<código>doc.AddImageUrl(url) <código>renderer.RenderUrlAsPdf(url) Conversión de URL a PDF
<código>doc.AddImageHtml(html) renderer.RenderHtmlAsPdf(html) Cadena HTML a PDF
<código>doc.AddImageFile(ruta)` <código>renderer.RenderHtmlFileAsPdf(ruta) Archivo HTML a PDF
doc.Read(path) <código>PdfDocument.FromFile(path)` Cargar PDF existente
doc.Guardar(ruta) <código>pdf.SaveAs(ruta)` Guardar en archivo
doc.GetData() <código>pdf.BinaryData` Obtener como matriz de bytes
doc.Clear() Uso de la frase using Eliminación automática

Métodos de manipulación de páginas

Método ABCpdf Método IronPDF Notas
doc.PageCount <código>pdf.PageCount` Mismo uso
doc.Page = n pdf.Pages[n-1] ABCpdf tiene 1 índice,IronPDFtiene 0 índices
<código>doc.Delete(pageId)` <código>pdf.RemovePages(index) Eliminar páginas
doc.Append(otroDoc) PdfDocument.Merge(pdf1, pdf2) Método de fusión estática
<código>doc.Rect.Inset(x, y)` <código>RenderingOptions.MarginTop/Bottom/Left/Right Márgenes

Métodos de seguridad y cifrado

Método ABCpdf Método IronPDF Notas
<código>doc.Cifrado.Contraseña <código>pdf.SecuritySettings.OwnerPassword Contraseña del propietario
<código>doc.Encryption.CanPrint <código>pdf.SecuritySettings.AllowUserPrinting Permiso de impresión
<código>doc.Encryption.CanCopy <código>pdf.SecuritySettings.AllowUserCopyPasteContent Autorización de copia
<código>doc.SetInfo("Título", valor) <código>pdf.MetaData.Title Metadatos del documento

Ejemplos de migración de código

Ejemplo 1: HTML a PDF desde URL

Este ejemplo muestra la conversión de una página web a PDF, una de las tareas de generación de PDF más comunes.

ABCpdf para la implementación de .NET:

// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;

class Program
{
    static void Main()
    {
        Doc doc = new Doc();
        doc.HtmlOptions.Engine = EngineType.Chrome;
        doc.AddImageUrl("https://www.example.com");
        doc.Save("output.pdf");
        doc.Clear();
    }
}
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;

class Program
{
    static void Main()
    {
        Doc doc = new Doc();
        doc.HtmlOptions.Engine = EngineType.Chrome;
        doc.AddImageUrl("https://www.example.com");
        doc.Save("output.pdf");
        doc.Clear();
    }
}
$vbLabelText   $csharpLabel

Implementación de IronPDF:

// NuGet: Install-Package IronPdf
using System;
using IronPdf;

class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        var pdf = renderer.RenderUrlAsPdf("https://www.example.com");
        pdf.SaveAs("output.pdf");
    }
}
// NuGet: Install-Package IronPdf
using System;
using IronPdf;

class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        var pdf = renderer.RenderUrlAsPdf("https://www.example.com");
        pdf.SaveAs("output.pdf");
    }
}
$vbLabelText   $csharpLabel

El enfoque deIronPDFelimina la necesidad de una configuración explícita del motor y la limpieza manual, reduciendo la complejidad del código y manteniendo al mismo tiempo todas las capacidades de renderización de Chrome.

Ejemplo 2: Cadena HTML a PDF

La conversión de cadenas HTML a PDF es esencial para generar informes y documentos dinámicos.

ABCpdf para la implementación de .NET:

// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;

class Program
{
    static void Main()
    {
        string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
        Doc doc = new Doc();
        doc.HtmlOptions.Engine = EngineType.Chrome;
        doc.AddImageHtml(html);
        doc.Save("output.pdf");
        doc.Clear();
    }
}
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;

class Program
{
    static void Main()
    {
        string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
        Doc doc = new Doc();
        doc.HtmlOptions.Engine = EngineType.Chrome;
        doc.AddImageHtml(html);
        doc.Save("output.pdf");
        doc.Clear();
    }
}
$vbLabelText   $csharpLabel

Implementación de IronPDF:

// NuGet: Install-Package IronPdf
using System;
using IronPdf;

class Program
{
    static void Main()
    {
        string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
        var renderer = new ChromePdfRenderer();
        var pdf = renderer.RenderHtmlAsPdf(html);
        pdf.SaveAs("output.pdf");
    }
}
// NuGet: Install-Package IronPdf
using System;
using IronPdf;

class Program
{
    static void Main()
    {
        string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
        var renderer = new ChromePdfRenderer();
        var pdf = renderer.RenderHtmlAsPdf(html);
        pdf.SaveAs("output.pdf");
    }
}
$vbLabelText   $csharpLabel

La versiónIronPDFrequiere menos líneas de código y utiliza el renderizado de Chrome por defecto, lo que garantiza un resultado coherente en todas las plataformas.

Ejemplo 3: Combinar varios PDF

La combinación de varios documentos PDF es un requisito frecuente en los flujos de trabajo de procesamiento de documentos.

ABCpdf para la implementación de .NET:

// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;

class Program
{
    static void Main()
    {
        Doc doc1 = new Doc();
        doc1.Read("document1.pdf");

        Doc doc2 = new Doc();
        doc2.Read("document2.pdf");

        doc1.Append(doc2);
        doc1.Save("merged.pdf");

        doc1.Clear();
        doc2.Clear();
    }
}
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;

class Program
{
    static void Main()
    {
        Doc doc1 = new Doc();
        doc1.Read("document1.pdf");

        Doc doc2 = new Doc();
        doc2.Read("document2.pdf");

        doc1.Append(doc2);
        doc1.Save("merged.pdf");

        doc1.Clear();
        doc2.Clear();
    }
}
$vbLabelText   $csharpLabel

Implementación de IronPDF:

// NuGet: Install-Package IronPdf
using System;
using System.Collections.Generic;
using IronPdf;

class Program
{
    static void Main()
    {
        var pdf1 = PdfDocument.FromFile("document1.pdf");
        var pdf2 = PdfDocument.FromFile("document2.pdf");

        var merged = PdfDocument.Merge(pdf1, pdf2);
        merged.SaveAs("merged.pdf");
    }
}
// NuGet: Install-Package IronPdf
using System;
using System.Collections.Generic;
using IronPdf;

class Program
{
    static void Main()
    {
        var pdf1 = PdfDocument.FromFile("document1.pdf");
        var pdf2 = PdfDocument.FromFile("document2.pdf");

        var merged = PdfDocument.Merge(pdf1, pdf2);
        merged.SaveAs("merged.pdf");
    }
}
$vbLabelText   $csharpLabel

El método estático Merge deIronPDFproporciona una API más limpia que acepta múltiples documentos, eliminando la necesidad de rastrear y borrar instancias individuales de Doc.

Ejemplo 4: Patrón de migración completo con márgenes

Este ejemplo muestra una migración completa antes/después para generar PDF con márgenes personalizados.

Antes (ABCpdf para .NET):

using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;

public byte[] GeneratePdf(string html)
{
    Doc doc = new Doc();
    doc.HtmlOptions.Engine = EngineType.Chrome;
    doc.Rect.Inset(20, 20);
    doc.AddImageHtml(html);
    byte[] data = doc.GetData();
    doc.Clear();  // Manual cleanup required
    return data;
}
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;

public byte[] GeneratePdf(string html)
{
    Doc doc = new Doc();
    doc.HtmlOptions.Engine = EngineType.Chrome;
    doc.Rect.Inset(20, 20);
    doc.AddImageHtml(html);
    byte[] data = doc.GetData();
    doc.Clear();  // Manual cleanup required
    return data;
}
$vbLabelText   $csharpLabel

Después (IronPDF):

using IronPdf;

public byte[] GeneratePdf(string html)
{
    var renderer = new ChromePdfRenderer();
    renderer.RenderingOptions.MarginTop = 20;
    renderer.RenderingOptions.MarginBottom = 20;
    renderer.RenderingOptions.MarginLeft = 20;
    renderer.RenderingOptions.MarginRight = 20;

    using var pdf = renderer.RenderHtmlAsPdf(html);
    return pdf.BinaryData;  // Automatic cleanup with 'using'
}
using IronPdf;

public byte[] GeneratePdf(string html)
{
    var renderer = new ChromePdfRenderer();
    renderer.RenderingOptions.MarginTop = 20;
    renderer.RenderingOptions.MarginBottom = 20;
    renderer.RenderingOptions.MarginLeft = 20;
    renderer.RenderingOptions.MarginRight = 20;

    using var pdf = renderer.RenderHtmlAsPdf(html);
    return pdf.BinaryData;  // Automatic cleanup with 'using'
}
$vbLabelText   $csharpLabel

Escenarios de migración avanzados

Aplicación web .NET Core

Para los equipos que crean aplicaciones web con .NET 6+ o que tienen previsto lanzar .NET 10 en 2025-2026, este es el patrón recomendado:

Patrón ABCpdf:

[HttpPost]
public IActionResult GeneratePdf([FromBody] ReportRequest request)
{
    Doc doc = new Doc();
    doc.HtmlOptions.Engine = EngineType.Chrome;
    doc.AddImageHtml(request.Html);
    byte[] pdfBytes = doc.GetData();
    doc.Clear();

    return File(pdfBytes, "application/pdf", "report.pdf");
}
[HttpPost]
public IActionResult GeneratePdf([FromBody] ReportRequest request)
{
    Doc doc = new Doc();
    doc.HtmlOptions.Engine = EngineType.Chrome;
    doc.AddImageHtml(request.Html);
    byte[] pdfBytes = doc.GetData();
    doc.Clear();

    return File(pdfBytes, "application/pdf", "report.pdf");
}
$vbLabelText   $csharpLabel

Patrón IronPDF:

[HttpPost]
public IActionResult GeneratePdf([FromBody] ReportRequest request)
{
    var renderer = new ChromePdfRenderer();
    using var pdf = renderer.RenderHtmlAsPdf(request.Html);

    return File(pdf.BinaryData, "application/pdf", "report.pdf");
}
[HttpPost]
public IActionResult GeneratePdf([FromBody] ReportRequest request)
{
    var renderer = new ChromePdfRenderer();
    using var pdf = renderer.RenderHtmlAsPdf(request.Html);

    return File(pdf.BinaryData, "application/pdf", "report.pdf");
}
$vbLabelText   $csharpLabel

Generación asíncrona de PDF

ABCpdf no tiene soporte nativo async.IronPDFofrece métodos de sincronización para mejorar el rendimiento de las aplicaciones web:

using IronPdf;

public async Task<byte[]> GeneratePdfAsync(string html)
{
    var renderer = new ChromePdfRenderer();
    using var pdf = await renderer.RenderHtmlAsPdfAsync(html);
    return pdf.BinaryData;
}
using IronPdf;

public async Task<byte[]> GeneratePdfAsync(string html)
{
    var renderer = new ChromePdfRenderer();
    using var pdf = await renderer.RenderHtmlAsPdfAsync(html);
    return pdf.BinaryData;
}
$vbLabelText   $csharpLabel

Configuración de la inyección de dependencias

RegistreIronPDFen aplicaciones .NET modernas utilizando patrones de C# 12+ compatibles con futuras versiones de C# 14:

// Program.cs (.NET 6+)
builder.Services.AddSingleton<ChromePdfRenderer>();

// Or create a service wrapper
public interface IPdfService
{
    Task<byte[]> GeneratePdfAsync(string html);
}

public class IronPdfService : IPdfService
{
    private readonly ChromePdfRenderer _renderer;

    public IronPdfService()
    {
        _renderer = new ChromePdfRenderer();
        _renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
    }

    public async Task<byte[]> GeneratePdfAsync(string html)
    {
        using var pdf = await _renderer.RenderHtmlAsPdfAsync(html);
        return pdf.BinaryData;
    }
}

// Register: builder.Services.AddSingleton<IPdfService, IronPdfService>();
// Program.cs (.NET 6+)
builder.Services.AddSingleton<ChromePdfRenderer>();

// Or create a service wrapper
public interface IPdfService
{
    Task<byte[]> GeneratePdfAsync(string html);
}

public class IronPdfService : IPdfService
{
    private readonly ChromePdfRenderer _renderer;

    public IronPdfService()
    {
        _renderer = new ChromePdfRenderer();
        _renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
    }

    public async Task<byte[]> GeneratePdfAsync(string html)
    {
        using var pdf = await _renderer.RenderHtmlAsPdfAsync(html);
        return pdf.BinaryData;
    }
}

// Register: builder.Services.AddSingleton<IPdfService, IronPdfService>();
$vbLabelText   $csharpLabel

Consejos para optimizar el rendimiento

Reutilizar el renderizador para operaciones por lotes

// Good: Single renderer instance
var renderer = new ChromePdfRenderer();
foreach (var html in htmlList)
{
    using var pdf = renderer.RenderHtmlAsPdf(html);
    pdf.SaveAs($"output_{i}.pdf");
}

// Bad: New renderer each time (slower startup)
foreach (var html in htmlList)
{
    var renderer = new ChromePdfRenderer(); // Overhead!
    using var pdf = renderer.RenderHtmlAsPdf(html);
    pdf.SaveAs($"output_{i}.pdf");
}
// Good: Single renderer instance
var renderer = new ChromePdfRenderer();
foreach (var html in htmlList)
{
    using var pdf = renderer.RenderHtmlAsPdf(html);
    pdf.SaveAs($"output_{i}.pdf");
}

// Bad: New renderer each time (slower startup)
foreach (var html in htmlList)
{
    var renderer = new ChromePdfRenderer(); // Overhead!
    using var pdf = renderer.RenderHtmlAsPdf(html);
    pdf.SaveAs($"output_{i}.pdf");
}
$vbLabelText   $csharpLabel

Comparación del uso de memoria

Escenario ABCpdf para .NET IronPDF Notas
PDF de 10 páginas ~80 MB ~50 MB IronPDFmás eficaz
Lote de 100 PDF Alto (limpieza manual) ~100 MB Utilice declaraciones using
HTML grande (5MB+) Variable ~150 MB Ambos necesitan fragmentación para documentos de gran tamaño

Solución de problemas comunes de migración

PDF se muestra en blanco

Síntoma: El PDF de salida tiene páginas vacías después de la migración.

Solución: Es posible que el contenido JavaScript no se cargue completamente antes de la renderización:

var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.WaitFor.RenderDelay(2000); // Wait 2 seconds
// Or wait for specific element:
renderer.RenderingOptions.WaitFor.HtmlElementById("content-loaded");
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.WaitFor.RenderDelay(2000); // Wait 2 seconds
// Or wait for specific element:
renderer.RenderingOptions.WaitFor.HtmlElementById("content-loaded");
$vbLabelText   $csharpLabel

No aparecen los encabezados/pies de página

Síntoma: TextHeader/TextFooter no visible en la salida.

Solución: Asegúrese de que los márgenes dejan espacio para el contenido del encabezado/pie de página:

var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.MarginTop = 40; // mm - leave room for header
renderer.RenderingOptions.MarginBottom = 40; // mm - leave room for footer

renderer.RenderingOptions.TextHeader = new TextHeaderFooter
{
    CenterText = "Header Text",
    FontSize = 12
};
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.MarginTop = 40; // mm - leave room for header
renderer.RenderingOptions.MarginBottom = 40; // mm - leave room for footer

renderer.RenderingOptions.TextHeader = new TextHeaderFooter
{
    CenterText = "Header Text",
    FontSize = 12
};
$vbLabelText   $csharpLabel

Lista de comprobación de la migración

Pre-Migración

  • Audite todo el uso de ABCpdf con grep -r &quot;WebSupergoo&quot; --include=&quot;*.cs&quot; .
  • Documentar los requisitos actuales de salida en PDF
  • Cree casos de prueba con salidas PDF de muestra para comparar
  • Obtener la clave de licencia de IronPDF
  • Código base de respaldo

Durante la migración

  • Eliminar el paquete NuGet de ABCpdf
  • Instalar el paquete NuGet de IronPdf
  • Agregar clave de licencia al inicio de la aplicación
  • Actualizar todas las declaraciones using
  • Convertir la instanciación Doc a ChromePdfRenderer
  • Reemplace doc.Clear()con declaraciones using
  • Actualizar llamadas a métodos por mapeo de API
  • Convertir diseños basados en coordenadas a márgenes CSS

Posmigración

  • Ejecutar todas las pruebas PDF existentes
  • Comparación visual de salidas PDF (ABCpdf vs IronPDF)
  • Pruebe todos los flujos de trabajo de PDF en el entorno de pruebas
  • Comparación de rendimiento
  • Eliminar la configuración de la licencia de ABCpdf
  • Actualizar las dependencias de la canalización de CI/CD
Curtis Chau
Escritor Técnico

Curtis Chau tiene una licenciatura en Ciencias de la Computación (Carleton University) y se especializa en el desarrollo front-end con experiencia en Node.js, TypeScript, JavaScript y React. Apasionado por crear interfaces de usuario intuitivas y estéticamente agradables, disfruta trabajando con frameworks modernos y creando manuales bien ...

Leer más