Kotlin JavaScript
Hoy vamos a hacer un pequeño tutorial sobre Kotlin generando JavaScript. Vamos a ver cómo crear un proyecto de Kotlin/JavaScript, cómo probarlo, cómo añadir librerías externas y cómo comunicarnos con JavaScript. En este artículo nos vamos a centrar en el lado de cliente, pero también se pueden hacer cosas con node.js.
En próximos artículos veremos como utilizar la popular librería PIXI.js y como hacer una aplicación para móvil con Apache Cordova.
- Creando un nuevo proyecto
- Configurando un html y probando el entorno
- Experimentando un poco
- Ejecutar con NW.js
Creando un nuevo proyecto
Vamos a utilizar intelliJ 15 community edition para el tutorial.
En primer lugar crearemos un nuevo proyecto de Kotlin / JavaScript como podemos ver en la figura.
En la siguiente pantalla tendremos que elegir el nombre del proyecto
y deberemos elegir una librería de Kotlin JS. Si no tenemos ninguna configurada
Pulsaremos en el botón Create...
que hay a la derecha.
Podemos indicarle que copie los archivos .js a la carpeta o que use la librería del plugin. Al final cuando generemos la salida los copiará. Así que podemos elegir uno indistintamente según nos interese.
Debería quedar algo así:
Configurando un html y probando el entorno
Lo siguiente que necesitaremos es una función main
y un index.html
para cargar en el navegador.
Creando función main
Crearemos un main.kt
con el siguiente código:
Las cosas que saquemos con println, acabarán saliendo por la consola consola de javascript.
Creando carpeta de assets
Lo siguiente que necesitaremos es una carpeta marcada como resources
para incluir ahí nuestros archivos adicionales: htmls, javascripts, css, imágenes…
Tras crear la carpeta assets
, crearemos un index.html
nuevo con el siguiente contenido:
Donde aparece kotlin-js-example.js
deberemos poner el nombre de nuestro proyecto.
Tras generar, si nos fijamos en la carpeta de salida, podremos ver cómo se llama exáctamente nuestro archivo javascript.
Ejecutando
Para poder ver el resultado necesitaremos compilar el proyecto a javascript.
Eso lo podemos hacer mediante Build -> Make Project
o su atajo correspondiente.
Eso nos debería generar una carpeta out/production/kotlin-js-example
con nuestro index.html
copiado de la carpeta de assets y los javascripts generados.
Si abrimos el index.html
con nuestro navegador favorito. Deberíamos poder ver algo como esto:
También nos podemos crear una run configuration que además de ejecutar nos abra un HTML.
El gutter icon de kotlin en la función main, no permite ejecutar todavía en kotlin js
Experimentando un poco
A partir de este momento ya deberíamos ser capaces de hacer cambios y verlos reflejados en el navegador.
En la versión 1.0 de Kotlin, el target de JavaScript es experiemntal y tiene limitaciones. Y no se soporta algunas cosas como clases dentro de funciones o reflexión. Obviamente tampoco podremos acceder a librerías Java y no están disponibles todas las apis de Kotlin (aunque sí gran parte).
Particularidades del target de javascript
Tenemos disponibles la anotación @native
, la propiedad global noImpl
, la función global especial js
y el tipo :dynamic
.
Anotación @native
y noImpl
@native
nos permite marcar clases, interfaces y funciones como nativas de forma que no se generará código para ellas
y se utilizará como si existiese en javascript.
Mientras que noImpl
es un getter global que devuelve :Nothing y que lanza una excepción, y que utilizaremos junto a
@native
en lugares donde debería haber código.
Functión global js
La función global js
nos permite embeber cualquier código javascript en un punto específico.
Tipo :dynamic
El tipo :dynamic
nos habilita un tipo dinámico con el que podemos acceder a cualquier propiedad como si existiese.
Mientras que Any
no expone ninguna propiedad y debemos convertirlo a otro objeto, :dynamic nos permite acceder a
cualquier propiedad o método como si existiese. Obviamente deberíamos limitar el uso de esta característica para evitar
perder las ventajas del tipado estricto.
Ejecutar con NW.js
Con NW.js podemos probar html en una ventana propia y podremos ver los mensajes de la consola de javascript desde el propio intelliJ con mucha facilidad y nos evitará necesitar lanzar un servidor web para hacer cierto tipo de operaciones que violasen las políticas de seguridad de archivos locales (por ejemplo peticiones ajax o acceso a archivos locales).
package.json
NW.js requiere un archivo package.json
que contiene información sobre nuestra aplicación.
Run configuration
Para poder utilizar nw.js necesitamos crear una run configuration
en la que haremos primero un make
del proyecto y después lanzaremos nw.js pasándole la ruta de la salida donde está nuestro package.json
y nuestro
index.html
.