Descripción general
El pago en línea te permite crear experiencias de pago completamente integradas que se mezclan sin problemas con tu sitio web o aplicación. A diferencia del pago en superposición, que se abre como un modal sobre tu página, el pago en línea incrusta el formulario de pago directamente en el diseño de tu página. Usando el pago en línea, puedes:- Crear experiencias de pago que están completamente integradas con tu aplicación o sitio web
- Permitir que Dodo Payments capture de forma segura la información del cliente y de pago en un marco de pago optimizado
- Mostrar artículos, totales y otra información de Dodo Payments en tu página
- Usar métodos y eventos del SDK para construir experiencias de pago avanzadas

Cómo funciona
El pago en línea funciona incrustando un marco seguro de Dodo Payments en tu sitio web o aplicación. El marco de pago se encarga de recopilar la información del cliente y capturar los detalles de pago. Tu página muestra la lista de artículos, totales y opciones para cambiar lo que hay en el pago. El SDK permite que tu página y el marco de pago interactúen entre sí. Dodo Payments crea automáticamente una suscripción cuando se completa un pago, lista para que la provisionen.El marco de inline checkout gestiona de forma segura toda la información de pago sensible, garantizando el cumplimiento de PCI sin que necesites certificación adicional.
¿Qué hace que un buen pago en línea?
Es importante que los clientes sepan de quién están comprando, qué están comprando y cuánto están pagando. Para construir un pago en línea que sea conforme y optimizado para la conversión, tu implementación debe incluir:
- Información recurrente: Si es recurrente, con qué frecuencia se repite y el total a pagar en la renovación. Si es una prueba, cuánto dura la prueba.
- Descripciones de artículos: Una descripción de lo que se está comprando.
- Totales de transacción: Totales de transacción, incluyendo subtotal, total de impuestos y total general. Asegúrate de incluir también la moneda.
- Pie de página de Dodo Payments: El marco completo de pago en línea, incluyendo el pie de página de pago que tiene información sobre Dodo Payments, nuestros términos de venta y nuestra política de privacidad.
- Política de reembolso: Un enlace a tu política de reembolso, si difiere de la política de reembolso estándar de Dodo Payments.
Viaje del cliente
El flujo de pago está determinado por la configuración de tu sesión de pago. Dependiendo de cómo configures la sesión de pago, los clientes experimentarán un pago que puede presentar toda la información en una sola página o a través de múltiples pasos.Customer opens checkout
Puedes abrir el pago en línea pasando artículos o una transacción existente. Usa el SDK para mostrar y actualizar la información en la página, y los métodos del SDK para actualizar los artículos según la interacción del cliente.

Customer enters their details
El pago en línea primero pide a los clientes que ingresen su dirección de correo electrónico, seleccionen su país y (donde sea necesario) ingresen su código postal. Este paso recopila toda la información necesaria para determinar impuestos y opciones de pago disponibles.Puedes prellenar los detalles del cliente y presentar direcciones guardadas para agilizar la experiencia.
Customer selects payment method
Después de ingresar sus datos, se presentan a los clientes los métodos de pago disponibles y el formulario de pago. Las opciones pueden incluir tarjeta de crédito o débito, PayPal, Apple Pay, Google Pay y otros métodos de pago locales según su ubicación.Muestra los métodos de pago guardados si están disponibles para acelerar el pago.

Checkout completed
Dodo Payments dirige cada pago al mejor adquirente para esa venta para obtener la mejor oportunidad de éxito. Los clientes ingresan a un flujo de éxito que puedes construir.

Inicio Rápido
Comienza con el Pago en Línea de Dodo Payments en solo unas pocas líneas de código:Guía de Integración Paso a Paso
Initialize the SDK for Inline Display
Inicializa el SDK y especifica
displayType: 'inline'. También debes escuchar el evento checkout.breakdown para actualizar tu interfaz de usuario con los cálculos de impuestos y totales en tiempo real.Open the Checkout
Llama a
DodoPayments.Checkout.open() con el checkoutUrl y el elementId de tu contenedor:Test Your Integration
- Inicia tu servidor de desarrollo:
- Prueba el flujo de pago:
- Ingresa tu correo electrónico y detalles de dirección en el marco en línea.
- Verifica que tu resumen de pedido personalizado se actualice en tiempo real.
- Prueba el flujo de pago usando credenciales de prueba.
- Confirma que las redirecciones funcionen correctamente.
Deberías ver eventos
checkout.breakdown registrados en la consola del navegador si agregaste un console.log en la devolución onEvent.Ejemplo Completo en React
Este ejemplo muestra cómo implementar un resumen de pedido personalizado junto al inline checkout, manteniéndolos sincronizados mediante el eventocheckout.breakdown.
Referencia de API
Configuración
Opciones de Inicialización
| Opción | Tipo | Requerido | Descripción |
|---|---|---|---|
mode | "test" | "live" | Sí | Modo de entorno. |
displayType | "inline" | "overlay" | Sí | Debe establecerse en "inline" para incrustar el checkout. |
onEvent | function | Sí | Función de devolución para manejar eventos del checkout. |
Opciones de Pago
| Opción | Tipo | Requerido | Descripción |
|---|---|---|---|
checkoutUrl | string | Sí | URL de la sesión de pago. |
elementId | string | Sí | El id del elemento DOM donde se debe renderizar el pago. |
options.showTimer | boolean | No | Mostrar u ocultar el temporizador de pago. Predeterminado a true. Cuando está deshabilitado, recibirás el evento checkout.link_expired cuando la sesión expire. |
options.showSecurityBadge | boolean | No | Mostrar u ocultar la insignia de seguridad. Predeterminado a true. |
options.payButtonText | string | No | Texto personalizado para mostrar en el botón de pago. |
options.fontSize | FontSize | No | Tamaño de fuente global para el pago. |
options.fontWeight | FontWeight | No | Peso de la fuente global para el pago. |
Métodos
Abrir Pago
Abre el marco de pago en el contenedor especificado.Cerrar Pago
Elimina programáticamente el marco de pago y limpia los listeners de eventos.Verificar Estado
Indica si el marco de pago está actualmente inyectado.Eventos
El SDK proporciona eventos en tiempo real a través del callbackonEvent. Para el pago en línea, checkout.breakdown es particularmente útil para sincronizar tu UI.
| Tipo de Evento | Descripción |
|---|---|
checkout.opened | El marco de pago ha sido cargado. |
checkout.form_ready | El formulario de pago está listo para recibir entrada del usuario. Útil para ocultar estados de carga y mostrar la interfaz de usuario de pago. |
checkout.breakdown | Se activa cuando se actualizan precios, impuestos o descuentos. |
checkout.customer_details_submitted | Se han enviado los detalles del cliente. |
checkout.pay_button_clicked | Se activa cuando el cliente hace clic en el botón de pago. Útil para análisis y seguimiento de embudos de conversión. |
checkout.redirect | El pago realizará una redirección (por ejemplo, a una página de banco). |
checkout.error | Ocurrió un error durante el pago. |
checkout.link_expired | Se activa cuando la sesión de pago expira. Solo se recibe cuando showTimer está configurado a false. |
Datos del Análisis del Pago
El eventocheckout.breakdown proporciona los siguientes datos:
Entendiendo el Evento de Análisis
El eventocheckout.breakdown es la forma principal de mantener la interfaz de usuario de tu aplicación sincronizada con el estado de pago de Dodo Payments.
Cuándo se activa:
- Al inicializar: Inmediatamente después de que se carga y lista el marco de pago.
- Al cambiar de dirección: Cada vez que el cliente selecciona un país o ingresa un código postal que resulta en un recálculo de impuestos.
| Campo | Descripción |
|---|---|
subTotal | La suma de todos los artículos de línea en la sesión antes de que se apliquen descuentos o impuestos. |
discount | El valor total de todos los descuentos aplicados. |
tax | El monto de impuestos calculado. En modo inline, esto se actualiza dinámicamente a medida que el usuario interactúa con los campos de dirección. |
total | El resultado matemático de subTotal - discount + tax en la moneda base de la sesión. |
currency | El código ISO de la moneda (por ejemplo, "USD") para los valores estándar de subtotal, descuento e impuestos. |
finalTotal | El monto real que se cobra al cliente. Esto puede incluir ajustes de cambio de divisa adicionales o tarifas de método de pago local que no son parte del desglose de precio básico. |
finalTotalCurrency | La moneda en la que el cliente está realmente pagando. Esto puede diferir de currency si la paridad del poder adquisitivo o la conversión de moneda local está activa. |
- Formato de Moneda: Los precios siempre se devuelven como enteros en la unidad monetaria más pequeña (por ejemplo, centavos para USD, yen para JPY). Para mostrarlos, divide por 100 (o la potencia de 10 correspondiente) o usa una biblioteca de formato como
Intl.NumberFormat. - Manejo de Estados Iniciales: Cuando el pago se carga por primera vez,
taxediscountpueden ser0onullhasta que el usuario proporcione su información de facturación o aplique un código. Tu UI debe manejar estos estados de manera adecuada (por ejemplo, mostrando un guion—u ocultando la fila). - El “Total Final” vs “Total”: Mientras que
totalte da el cálculo de precio estándar,finalTotales la fuente de verdad para la transacción. SifinalTotalestá presente, refleja exactamente lo que se cargará a la tarjeta del cliente, incluyendo cualquier ajuste dinámico. - Retroalimentación en Tiempo Real: Usa el campo
taxpara mostrar a los usuarios que los impuestos están siendo calculados en tiempo real. Esto proporciona una sensación de “en vivo” a tu página de pago y reduce la fricción durante el paso de ingreso de dirección.
Opciones de Implementación
Instalación del Gestor de Paquetes
Instala vía npm, yarn o pnpm como se muestra en la Guía de Integración Paso a Paso.Implementación vía CDN
Para una integración rápida sin un paso de compilación, puedes usar nuestro CDN:Actualizar Método de Pago
El pago en línea admite actualizaciones de método de pago para suscripciones. Cuando un cliente necesita actualizar su método de pago — ya sea para una suscripción activa o para reactivar una suscripción en espera — puedes renderizar el flujo de actualización directamente dentro de la disposición de tu página.Cómo Funciona
- Llama a la API de Actualización de Método de Pago para obtener un
payment_link:
- Pasa el
payment_linkdevuelto como elcheckoutUrlpara abrir el pago en línea:
Para Suscripciones en Espera
Al actualizar el método de pago para una suscripción en estadoon_hold, Dodo Payments automáticamente crea un cargo por cualquier deuda pendiente. Monitorea los webhooks payment.succeeded e subscription.active para confirmar la reactivación.
Manejo de Errores
El SDK proporciona información detallada sobre errores a través del sistema de eventos. Siempre implementa un manejo adecuado de errores en tu callbackonEvent:
Mejores Prácticas
- Diseño Responsivo: Asegúrate de que tu elemento contenedor tenga suficiente ancho y alto. El iframe típicamente se expandirá para llenar su contenedor.
- Sincronización: Usa el evento
checkout.breakdownpara mantener tu resumen de pedido personalizado o tablas de precios sincronizados con lo que el usuario ve en el marco de pago. - Estados de Esqueleto: Muestra un indicador de carga en tu contenedor hasta que se active el evento
checkout.opened. - Limpieza: Llama a
DodoPayments.Checkout.close()cuando tu componente se desmonte para limpiar el iframe y los listeners de eventos.
Para implementaciones en modo oscuro, se recomienda usar
#0d0d0d como el color de fondo para una integración visual óptima con el marco de pago en línea.Validación de Estado de Pago
Por Qué la Validación del Lado del Servidor es Esencial
Aunque los eventos de pago en línea proporcionan retroalimentación en tiempo real, no deben ser tu única fuente de verdad para el estado de pago. Problemas de red, fallos del navegador o el cierre de la página por parte de los usuarios pueden hacer que se pierdan eventos. Para asegurar una validación de pago confiable:- Tu servidor debe escuchar eventos webhook - Dodo Payments envía webhooks para cambios de estado de pago
- Implementa un mecanismo de sondeo - Tu frontend debe sondear a tu servidor para actualizaciones de estado
- Combina ambos enfoques - Usa webhooks como fuente principal y sondeo como respaldo
Arquitectura Recomendad
Pasos de Implementación
1. Escucha eventos de pago - Cuando el usuario hace clic en pagar, comienza a prepararte para verificar el estado:payment.succeeded o payment.failed. Consulta nuestra documentación de Webhooks para más detalles.
Solución de Problemas
Checkout frame is not appearing
Checkout frame is not appearing
- Verifica que
elementIdcoincida con elidde undivque realmente exista en el DOM. - Asegúrate de que
displayType: 'inline'haya sido pasado aInitialize. - Revisa que el
checkoutUrlsea válido.
Taxes are not updating in my UI
Taxes are not updating in my UI
- Asegúrate de estar escuchando el evento
checkout.breakdown. - Los impuestos solo se calculan después de que el usuario ingrese un país y código postal válidos en el marco de pago.
Habilitación de Billeteras Digitales
Para información detallada sobre cómo configurar Apple Pay, Google Pay y otras billeteras digitales, consulta la página de Billeteras Digitales.Configuración Rápida para Apple Pay
Download domain association file
Descarga el archivo de asociación de dominio de Apple Pay.
Request activation
Envía un correo electrónico a support@dodopayments.com con la URL de tu dominio de producción y solicita la activación de Apple Pay.
Soporte de Navegadores
El SDK de Pagos Dodo admite los siguientes navegadores:- Chrome (última versión)
- Firefox (última versión)
- Safari (última versión)
- Edge (última versión)
- IE11+
Pago En Línea vs Pago Superpuesto
Elige el tipo de pago adecuado para tu caso de uso:| Característica | Pago En Línea | Pago Superpuesto |
|---|---|---|
| Profundidad de integración | Completamente incrustado en la página | Modal sobre la página |
| Control de diseño | Control total | Limitado |
| Marca | Fluida | Separada de la página |
| Esfuerzo de implementación | Mayor | Menor |
| Mejor para | Páginas de pago personalizadas, flujos de alta conversión | Integración rápida, páginas existentes |
Recursos Relacionados
Overlay Checkout
Usa el pago superpuesto para una integración rápida basada en modal.
Checkout Sessions API
Crea sesiones de pago para impulsar tus experiencias de pago.
Webhooks
Maneja eventos de pago del lado del servidor con webhooks.
Integration Guide
Guía completa para integrar Dodo Payments.
