Contexto
Los pasos de Contexto te permiten crear y actualizar una o más variables para un usuario a medida que avanza por un Canvas. Por ejemplo, si tienes un Canvas que gestiona descuentos de temporada, puedes usar una variable de contexto para almacenar un código de descuento diferente cada vez que un usuario entra en el Canvas.
Cómo funciona

Los pasos de Contexto te permiten crear y usar datos temporales durante el recorrido de un usuario a través de un Canvas específico. Estos datos existen solo dentro de ese recorrido del Canvas y no persisten entre diferentes Canvas ni fuera de la sesión.
Las variables de contexto existen solo para ese recorrido específico del Canvas. No cambian el perfil del usuario de forma permanente y no aparecen en otros Canvas. Esto las hace ideales para información temporal que solo es relevante para una campaña o flujo de trabajo específico.
Para una referencia completa sobre las variables de contexto, incluyendo tipos de datos, uso y mejores prácticas, consulta la referencia de variables de contexto.
Dentro de un paso de Contexto, puedes definir o actualizar hasta 10 variables de contexto. Estas variables se pueden usar para personalizar retrasos, segmentar usuarios dinámicamente y enriquecer la mensajería a lo largo del Canvas. Por ejemplo, podrías crear una variable de contexto para la hora de vuelo programada de un usuario y luego usarla para establecer retrasos personalizados y enviar recordatorios.
Puedes establecer variables de contexto de dos formas:
- En la entrada del Canvas: Las propiedades del evento personalizado o del desencadenador de API se rellenan automáticamente como variables de contexto.
- En un paso de Contexto: Define o actualiza variables de contexto manualmente añadiendo un paso de Contexto.
Cada variable de contexto requiere un nombre, un tipo de datos y un valor (establecido usando Liquid o la herramienta Añadir personalización). Una vez definidas, puedes hacer referencia a las variables de contexto en todo el Canvas usando Liquid, como {{context.${flight_time}}}. En el campo Nombre de la variable de contexto, también puedes introducir el nombre de la variable de contexto o seleccionarlo del menú desplegable en el editor de pasos. Para más detalles, consulta la referencia de variables de contexto.
Cada entrada al Canvas redefine las variables de contexto basándose en los datos de entrada más recientes y la configuración del Canvas, lo que permite que los usuarios tengan múltiples recorridos activos con su propio contexto. Por ejemplo, si un cliente tiene dos vuelos próximos, tendrá dos estados de recorrido separados ejecutándose simultáneamente—cada uno con sus propias variables de contexto específicas del vuelo, como hora de salida y destino. Esto te permite enviar recordatorios personalizados sobre su vuelo de las 2 pm a Nueva York mientras envías actualizaciones diferentes sobre su vuelo de las 8 am a Los Ángeles mañana, de modo que cada mensaje sea relevante para la reserva específica.
Procesamiento de usuarios y procesamiento por lotes
Los pasos de Contexto procesan usuarios en lotes para optimizar el rendimiento. Cuando los usuarios entran en un paso de Contexto, Braze los procesa en lotes de 1000 usuarios de forma predeterminada. Estos lotes se procesan en paralelo, pero dentro de cada lote, los usuarios se procesan secuencialmente.
Esto significa:
Ejemplo: Si 3500 usuarios entran en un paso de Contexto con Contenido conectado que tarda 650 ms por usuario:
- Braze crea 4 lotes de usuarios (1000, 1000, 1000 y 500 usuarios en este ejemplo).
- Cada lote procesa usuarios secuencialmente, por lo que un lote de 1000 usuarios tarda aproximadamente 10,8 minutos (650 segundos; 1000 × 650 ms).
- Los lotes se completan en diferentes momentos, por lo que los usuarios van pasando al siguiente paso a medida que su lote termina.
- Los primeros usuarios pueden llegar al siguiente paso varios minutos antes que los últimos usuarios, dependiendo del tamaño del lote y los tiempos de respuesta del Contenido conectado.
Sin Contenido conectado, los pasos de Contexto se procesan mucho más rápido porque no hay llamadas a API externas que esperar.
Consideraciones
- Puedes definir hasta 10 variables de contexto por paso de Contexto.
- Cada variable requiere un nombre único (solo letras, números y guiones bajos, hasta 100 caracteres).
- El tamaño total de todas las variables en un paso no puede superar los 50 KB.
- Las variables pasadas mediante desencadenadores de API comparten el mismo espacio de nombres que las creadas en los pasos de Contexto; redefinir una variable en un paso de Contexto sobrescribe el valor de la API.
Para más detalles y uso avanzado, consulta la referencia de variables de contexto.
Crear un paso de Contexto
No necesitas un paso de contexto para hacer referencia a las propiedades del evento desencadenante en los pasos de ruta de audiencia o paso para la división de decisiones. Puedes hacer referencia a las propiedades directamente en los grupos de filtros con el filtro Variable de contexto. Asegúrate de seleccionar el tipo de datos correcto.
Paso 1: Añadir un paso
Añade un paso a tu Canvas, luego arrastra y suelta el componente desde la barra lateral, o selecciona el botón más y selecciona Contexto.
Paso 2: Definir las variables
Puedes definir hasta 10 variables de contexto para cada paso de Contexto.
Para definir una variable de contexto:
- Dale un nombre a tu variable de contexto.
- Selecciona un tipo de datos.
- Escribe una expresión Liquid manualmente o usa Añadir personalización para crear un fragmento de código Liquid a partir de atributos preexistentes.
- Selecciona Vista previa para comprobar el valor de tu variable de contexto.
- (Opcional) Para añadir variables adicionales, selecciona Añadir variable de contexto y repite los pasos 1-4.
- Cuando hayas terminado, selecciona Listo.
Ahora puedes usar tu variable de contexto en cualquier lugar donde uses Liquid, como en los pasos de Mensaje y Actualización de usuario, seleccionando Añadir personalización. En el campo Nombre de la variable de contexto, también puedes introducir el nombre de la variable de contexto o seleccionarlo del menú desplegable en el editor de pasos. Para un recorrido completo, consulta la referencia de variables de contexto.
Al hacer referencia a variables de contexto, usa siempre el formato {{context.${variable_name}}}.
Filtros de variables de contexto
Puedes crear filtros usando variables de contexto en los pasos de Rutas de audiencia y División de decisiones. Para la configuración de filtros, lógica de comparación y ejemplos avanzados, consulta la referencia de variables de contexto.
Elegir entre los tipos de filtro «Día del año» y «Hora»: al filtrar variables de contexto que contienen fechas, elige el tipo de comparación correcto en función de si la fecha se repite cada año:
- Usa «Día del año» cuando la fecha se repita cada año (por ejemplo, cumpleaños, aniversarios o fiestas como Navidad). Este tipo de comparación calcula en función del día del año (1-365/366), ignorando el componente del año.
- Usa «Hora» cuando la fecha sea una fecha absoluta que no se repita (por ejemplo, fechas de finalización de contratos, fechas de citas o fechas de renovación de suscripciones). Este tipo de comparación calcula basándose en la marca de tiempo completa, incluido el año.
El uso de «Día del año» para fechas absolutas puede producir resultados incorrectos o inesperados, ya que el cálculo ignora el componente del año. Por ejemplo, si comparas la fecha de vencimiento de un contrato futuro en abril para determinar si está dentro de los 63 días, el uso de «Día del año» puede hacer que las fechas coincidan incorrectamente, ya que solo compara los números de los días (119 frente a 359) sin tener en cuenta que, en realidad, quedan 188 días para abril.
Directriz general: ¿la fecha se repite cada año? Sí → Usa «Día del año». No → Usa «Hora».
Previsualizar rutas de usuario
Recomendamos probar y previsualizar tus rutas de usuario para asegurarte de que tus mensajes se envían a la audiencia correcta y que las variables de contexto se evalúan con los resultados esperados.
Si estás previsualizando tu Canvas en la sección Vista previa y envío de prueba del editor, la marca de tiempo en la vista previa del mensaje de prueba no se estandariza a UTC porque este panel genera las vistas previas como cadenas. Esto significa que si un Canvas está configurado para aceptar un objeto time, la vista previa del mensaje no refleja con precisión lo que ocurre cuando el Canvas está en vivo. Para probar tu Canvas con la mayor precisión, recomendamos previsualizar las rutas de usuario en su lugar.
Asegúrate de observar cualquier escenario común que cree variables de contexto no válidas. Al previsualizar tu ruta de usuario, puedes ver los resultados de los pasos de Retraso personalizados que usan variables de contexto, y cualquier comparación de pasos de audiencia o decisión que coincida con usuarios según variables de contexto.
Si la variable de contexto es válida, puedes hacer referencia a la variable en todo tu Canvas. Sin embargo, si la variable de contexto no se creó correctamente, los pasos futuros en tu Canvas tampoco funcionarán correctamente. Por ejemplo, si creas un paso de Contexto para asignar a los usuarios una hora de cita y estableces el valor de la hora de cita con una fecha pasada, el correo electrónico de recordatorio en tu paso de Mensaje no se envía.
Convertir cadenas de Contenido conectado a JSON
Al hacer una llamada de Contenido conectado en un paso de Contexto, el JSON devuelto por la llamada se evalúa como un tipo de datos de cadena para mantener la consistencia y prevenir errores. Si quieres convertir esta cadena a JSON, conviértela usando as_json_string. Por ejemplo:
1
2
{% connected_content http://example.com :save product %}
{{ product | as_json_string }}
Solución de problemas
Variables de contexto no válidas
Una variable de contexto se considera no válida cuando:
- Una llamada a un Contenido conectado integrado falla.
- La expresión Liquid en tiempo de ejecución devuelve un valor que no coincide con el tipo de datos o está vacío (nulo).
Por ejemplo, si el tipo de datos de la variable de contexto es Número pero la expresión Liquid devuelve una cadena, es no válida.
En estas circunstancias:
- El usuario avanza al siguiente paso.
- El análisis del paso en Canvas cuenta esto como No actualizado.
Al solucionar problemas, monitoriza la métrica No actualizado para verificar que tu variable de contexto se está actualizando correctamente. Si la variable de contexto es no válida, tus usuarios pueden continuar en tu Canvas más allá del paso de Contexto, pero pueden no calificar para pasos posteriores.
Consulta Tipos de datos para ver las configuraciones de ejemplo para cada tipo de datos.
Retrasos en el envío con Contenido conectado
Todos los usuarios en un lote se procesan antes de que cualquier usuario avance. Después de que se completa el procesamiento del lote, los usuarios exitosos pasan al siguiente paso, mientras que los usuarios fallidos se reintentan por separado; los usuarios exitosos no esperan a que los reintentos tengan éxito antes de avanzar.
Comportamiento de reintento
En los pasos de Canvas (incluidos los pasos de Contexto), Braze usa mecanismos de reintento específicos de Canvas en lugar del comportamiento estándar de reintento de Contenido conectado. Si una llamada de Contenido conectado falla:
- Para los pasos de Mensaje, las llamadas de Contenido conectado pueden reintentarse hasta cinco veces.
- Para todos los demás pasos, Braze reintenta el paso aproximadamente 13 veces con retirada exponencial.
Si todos los reintentos fallan, el usuario sale del Canvas.
La etiqueta :retry usada en el Contenido conectado estándar no se aplica a las llamadas de Contenido conectado realizadas dentro de los pasos de Canvas. Los pasos de Canvas tienen su propia lógica de reintento optimizada para flujos de trabajo de Canvas.
El tiempo que tarda en procesar a todos los usuarios a través de un paso de Contexto depende de:
- El número de usuarios que entran en el paso
- Si se usa Contenido conectado (y su tiempo de respuesta)
- El tamaño del lote (predeterminado: 1000 usuarios por lote)
Si tu punto de conexión de Contenido conectado tiene límites de velocidad, ten en cuenta que los pasos de Contexto procesan usuarios secuencialmente dentro de cada lote, lo que ayuda a respetar los límites de velocidad de forma natural. Sin embargo, múltiples lotes se procesan en paralelo, así que asegúrate de que tu punto de conexión pueda manejar solicitudes concurrentes de múltiples lotes.
Estandarización de consistencia de zona horaria
Con la disponibilidad general de Canvas Context, todas las propiedades de eventos de marca de tiempo predeterminadas en Canvas basados en acciones están en UTC. Este cambio es parte de un esfuerzo más amplio para garantizar una experiencia más predecible y consistente al editar pasos y mensajes de Canvas. Ten en cuenta que este cambio afecta a todos los Canvas basados en acciones, independientemente de si el Canvas específico está usando un paso de Contexto o no.
En todas las circunstancias, recomendamos encarecidamente usar filtros de zona horaria de Liquid para que las marcas de tiempo se representen en la zona horaria deseada. Puedes consultar esta pregunta frecuente para ver un ejemplo.
Preguntas frecuentes
¿Qué ha cambiado desde que Canvas Context está disponible de forma general?
Ahora que Canvas Context está disponible de forma general, se aplican los siguientes detalles:
- Todas las marcas de tiempo con un tipo datetime de las propiedades de eventos desencadenadores en Canvas basados en acciones están en UTC.
- Este cambio afecta a todos los Canvas basados en acciones, independientemente de si el Canvas específico está usando un paso de Contexto o no.
¿Cuál es la razón de este cambio?
Este cambio es parte de un esfuerzo más amplio para crear una experiencia más predecible y consistente al editar pasos y mensajes de Canvas.
¿Se ven afectados los Canvas desencadenados por API o planificados por este cambio?
No.
¿Este cambio afecta a las propiedades de entrada del Canvas?
Sí, esto afecta a canvas_entry_properties si la canvas_entry_property se está usando en un Canvas basado en acciones y el tipo de propiedad es time. En todas las circunstancias, recomendamos usar filtros time_zone de Liquid para que las marcas de tiempo se representen en la zona horaria deseada.
Aquí tienes un ejemplo de cómo hacerlo:
| Liquid en el paso de Mensaje | Resultado | ¿Es esta la forma correcta de representar zonas horarias en Liquid? |
|---|---|---|
{{canvas_entry_properties.${timestamp_property}}} |
2025-08-05T08:15:30:250-0800 |
No |
{{canvas_entry_properties.${timestamp_property} | date: "%Y-%m-%d %l:%M %p"}} |
2025-08-05 4:15pm |
No |
{{canvas_entry_properties.${timestamp_property} | time_zone: "America/Los_Angeles" | date: "%Y-%m-%d %l:%M %p"}} |
2025-08-05 8:15am |
Sí |
¿Cuál es un ejemplo práctico de cómo el nuevo comportamiento de marcas de tiempo podría afectar mis mensajes?
Supongamos que tenemos un Canvas basado en acciones que tiene el siguiente contenido en un paso de Mensaje:
1
Your appointment is scheduled for {{canvas_entry_properties.${appointment_time} | date: "%Y-%m-%d %l:%M %p"}}, we'll see you then!
Esto produce el siguiente mensaje:
1
Your appointment is scheduled for 2025-08-05 4:15 PM, we’ll see you then!
Como no se especifica ninguna zona horaria usando Liquid, la marca de tiempo aquí está en UTC.
Para especificar una zona horaria claramente, podemos usar filtros time_zone de Liquid así:
1
Your appointment is scheduled for {{canvas_entry_properties.${appointment_time} | time_zone: "America/Los_Angeles" | date: "%Y-%m-%d %l:%M %p"}}, we'll see you then!
Esto produce el siguiente mensaje:
1
Your appointment is scheduled for 2025-08-05 8:15 AM, we'll see you then!
Como la zona horaria America/Los Angeles se especifica usando Liquid, la marca de tiempo aquí está en PST.
La zona horaria preferida también se puede enviar en la carga útil de propiedades del evento y usarse en la lógica de Liquid:
1
2
3
4
{
"appointment_time": "2025-08-05T08:15:30:250-0800"
"user_timezone": "America/Los_Angeles"
}
¿En qué se diferencian las variables de contexto de las propiedades de entrada del Canvas?
Las propiedades de entrada del Canvas se incluyen como variables de contexto del Canvas. Esto significa que puedes enviar propiedades de entrada del Canvas usando la API de Braze y hacer referencia a ellas en otros pasos, de forma similar a usar una variable de contexto con el fragmento de código Liquid.
¿Pueden las variables hacer referencia entre sí en un mismo paso de Contexto?
Sí. Todas las variables en un paso de Contexto se evalúan en secuencia, lo que significa que podrías tener las siguientes variables de contexto configuradas:
| Variable de contexto | Valor | Descripción |
|---|---|---|
favorite_cuisine |
{{custom_attribute.${Favorite Cuisine}}} |
El tipo de cocina favorita de un usuario. |
promo_code |
EATFRESH |
El código de descuento disponible para un usuario. |
personalized_message |
"Enjoy a discount of" {{context.${promo_code}}} "on delivery from your favorite" {{context.${favorite_cuisine}}} restaurants!" |
Un mensaje personalizado que combina las variables anteriores. En un paso de Mensaje, podrías usar el fragmento de código Liquid {{context.${personalized_message}}} para hacer referencia a la variable de contexto y entregar un mensaje personalizado a cada usuario. También podrías usar un paso de Contexto para guardar el valor del código de promoción y usarlo como plantilla en otros pasos a lo largo de un Canvas. |
Esto también aplica entre múltiples pasos de Contexto. Por ejemplo, imagina esta secuencia:
- Un paso de Contexto inicial crea una variable llamada
JobInfocon el valorjob_title. - Un paso de Mensaje hace referencia a
{{context.${JobInfo}}}y muestrajob_titleal usuario. - Más adelante, un paso de Contexto actualiza la variable de contexto, cambiando el valor de
JobInfoajob_description. - Todos los pasos posteriores que hacen referencia a
JobInfoahora usan el valor actualizadojob_description.
Las variables de contexto usan su valor más reciente a lo largo del Canvas, y cada actualización afecta a todos los pasos siguientes que hacen referencia a esa variable.