Skip to content
forked from Glidias/haxevx

HaxeVX - Haxe-powered VueJS/Vuex development. Why? So you can write HTML application/interface templates in fully strict-typed-safe Haxe, while using haxevx as a seamless bridge to your existing Haxe codebases/classes, keeping the benefits of OO/encapsulation and cross-platform inter-operability within your Haxe codesbase itself.

Notifications You must be signed in to change notification settings

firefalcom/haxevx

 
 

Repository files navigation

haxevx

HaxeVX - Haxe-powered VueJS/Vuex development

Official release of core library is available on Haxelib.

haxelib install haxevx

Important Note: If your Vue/Vuex externs are loaded into your project globally (ie. not using require() modules ), you need to compile your Haxe code with the flag -D vue_global, in order to reference them globally as well.

Type-safe coding to target Vuex/VueJS environments using Haxe pre-compile-time Macros and Classes.

With HaxeVx, you get the benefit of massive access-control/type-hinting/type-checking/compile-time safety, etc. inherant within Haxe when developing your VueJS/Vuex stuff. Compile-time mixins/macros/checks are provided specifically for your Haxe classes to ensure they conform to the necessary VueJS conventions.

Overview of features:

  • Automatic mixing-in of typed Props and Data (classes/typedefs) fields into your Vue instance with full type-safety during development. eg. class MyComponent extends VComponent<DataType, PropType>. Unlike regular VueJS, mixed-in fields in HaxeVx can be accessed locally within your Vue instance class definition with full strict-typing. Thus, if Props+Data fields conflict in name-clashes, the compiler will know it

  • Unlike Typescript decorators that execute at run-time, all HaxeVx metadata (if any), in components, are compile-time-only metadata used to facilitate pre-generation of initialization code. There is no further iteration processing done at runtime beyond calling a single automatically-called internal macro-generated function that exposes all pre-compiled component options to Vue already. So, based on the class you write (props/data-types/functions, etc.), the necessary Vue-related initialization options will automatically be pre-generated for you already.

  • Fully strict typed access on $data reference as well.

  • Comprehensive Vue-specific compile time type/reference/convention checking is involved in the macro compile process (eg. ensuring any watcher field links are spelled-correctly to an existing computed/data/prop field in the Vue instance, ensuring your Vue component prop fields are non-public, etc.). Because of the static typed approach of Haxe-Vx, a lot fo things can be pre-checked at compile-time.

  • Vuex: A library/scheme in Haxe specially tailored for Vuex as well, that provides fully type-safe commit/dispatch payloads without having to manage any strings/string-constants or namespacings. This results in fewer errors and reduced boilerplate in linking up your actions/mutations/getters.

Here is a guide/spec of features that are supported in HaxeVx for Vue.

https://github.com/Glidias/haxevx/wiki/Vue---HaxeVX-Draft-version-guide

A guide to using HaxeVx for Vuex.

https://github.com/Glidias/haxevx/wiki/Vuex---HaxeVX-Draft-version-guide

Examples:

A Vuex example (ie. the port of Vuex' Shopping Cart Example), can be found here:

https://github.com/Glidias/haxevx/tree/master/src/haxevx/vuex/examples/shoppingcart

Or you can view the examples package for anything else: https://github.com/Glidias/haxevx/tree/master/src/haxevx/vuex/examples/

Other full-fledged examples online: https://github.com/Glidias/haxevx/wiki/Gallery-Links


Roadmap can be found here


Versioning:

HaxeVx was developed for Haxe version 3.3.0 or later. Note that if you are using version 3.4, make sure you have the very latest version from year 2017 onwards.


Deployment info:

The current package is under haxevx.vuex* namespace. Examples folder can be omitted for deployment.


Main links:

VueJS - https://vuejs.org/ Vuex - https://vuex.vuejs.org/en Haxe - http://haxe.org

About

HaxeVX - Haxe-powered VueJS/Vuex development. Why? So you can write HTML application/interface templates in fully strict-typed-safe Haxe, while using haxevx as a seamless bridge to your existing Haxe codebases/classes, keeping the benefits of OO/encapsulation and cross-platform inter-operability within your Haxe codesbase itself.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 68.8%
  • Haxe 31.1%
  • HTML 0.1%