Extensión de VSCode
Si usas VisualStudio Code, instala la extensión Jinja-Jx.
Resaltado de sintaxis
La extensión provee resaltado de sintaxis completo para archivos .jx, incluyendo:
- Pragmas de Jx:
{#import ... #},{#def ... #},{#css ... #},{#js ... #} - Etiquetas de componentes en PascalCase (por ejemplo,
<MyComponent>,<Card />) - Expresiones (
{{ ... }}), sentencias ({% ... %}) y comentarios ({# ... #}) de Jinja2 - HTML estándar (heredado de la gramática HTML integrada de VS Code)

Ve a la definición
Ctrl+clic (o Cmd+clic en macOS) para saltar al archivo de un componente. Esto funciona desde tres lugares:
- La ruta de importación — haz clic en la cadena dentro de
{#import "card.jx" as Card #} - El nombre del alias — haz clic en
Carden la declaración de importación - Una etiqueta de componente — haz clic en
<Card>o</Card>en cualquier parte de la plantilla
La extensión resuelve rutas usando las carpetas de tu catálogo (autodetectadas desde archivos Python), rutas relativas (./, ../) y rutas con prefijo (@ui/modal.jx).
Diagnósticos
La extensión ejecuta jx check automáticamente y muestra los errores en línea en el editor. Las verificaciones se ejecutan:
- Al guardar (archivos
.jxy.py) - Al abrir un archivo
.jx - Al iniciar

Los errores aparecen en el panel Problems y como subrayados en rojo en el editor, incluyendo sugerencias del tipo "¿quisiste decir?" para errores tipográficos.
Esto usa el mismo verificador que el validador de CLI — consulta esa página para detalles sobre lo que se verifica.
Snippets
Escribe un prefijo y presiona Tab para expandirlo:
| Prefijo | Se expande a |
|---|---|
jximport |
{#import "..." as ... #} |
jxdef |
{#def ... #} |
jxcss |
{#css ... #} |
jxjs |
{#js ... #} |
jxslot |
{% slot name %} ... {% endslot %} |
jxfill |
{% fill name %} ... {% endfill %} |
jxcomp |
Esqueleto completo de componente (import, css, js, def) |
Formateo
La extensión provee formateo de documento (Shift+Alt+F) delegando al formateador HTML integrado de VS Code. Se respetan tus ajustes de formateo HTML (indentación, ajuste de líneas, etc.).
Autodetección
La extensión escanea automáticamente tu workspace en busca de archivos Python que usen Catalog() o .add_folder() para detectar:
- Rutas de carpetas de componentes (usadas por ir a la definición)
- Rutas de importación del catálogo (usadas por los diagnósticos)
Si no se encuentra ninguna llamada a Catalog(), recurre a buscar archivos .jx dentro de carpetas con nombres conocidos (views, components, templates).
El escaneo se vuelve a ejecutar cada vez que se crea, modifica o elimina un archivo .py.
Instalación
Abre VSCode Quick Open (Ctrl+P), pega el siguiente comando y presiona ENTER.
ext install jpscaletti.jinja-jx
Alternativamente:
- Descarga el archivo
jinja-jx-VERSION.vsixdesde el repositorio de GitHub - Abre VSCode Quick Command (Shift+Ctrl+P)
- Ejecuta "Extensions: Install from VSIX..."
Configuración
Todos los ajustes son opcionales — la extensión funciona sin configuración gracias a la autodetección.
| Ajuste | Por defecto | Descripción |
|---|---|---|
jx.check.enabled |
true |
Habilita o deshabilita los diagnósticos |
jx.pythonPath |
"" |
Ruta al intérprete de Python. Se autodetecta desde la extensión de Python o desde PATH si está vacío |
jx.catalogPath |
"" |
Ruta de importación a tu instancia de Catalog (por ejemplo, myapp.setup:catalog). Se autodetecta si está vacío |