Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/elsassph/haxe-modular
Haxe-JS code splitting, NPM dependencies bundling, hot-reload
https://github.com/elsassph/haxe-modular
code-splitting haxe javascript
Last synced: 1 day ago
JSON representation
Haxe-JS code splitting, NPM dependencies bundling, hot-reload
- Host: GitHub
- URL: https://github.com/elsassph/haxe-modular
- Owner: elsassph
- Created: 2016-11-19T21:39:27.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2022-04-26T09:15:48.000Z (over 2 years ago)
- Last Synced: 2024-12-26T02:11:56.360Z (8 days ago)
- Topics: code-splitting, haxe, javascript
- Language: Haxe
- Homepage:
- Size: 516 KB
- Stars: 116
- Watchers: 11
- Forks: 14
- Open Issues: 14
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# Haxe Modular
[![TravisCI Build Status](https://travis-ci.org/elsassph/haxe-modular.svg?branch=master)](https://travis-ci.org/elsassph/haxe-modular)
[![Haxelib Version](https://img.shields.io/github/tag/elsassph/haxe-modular.svg?label=haxelib)](http://lib.haxe.org/p/modular)
[![npm Version](https://img.shields.io/npm/v/haxe-modular.svg)](https://www.npmjs.com/package/haxe-modular)
[![Downloads](http://img.shields.io/npm/dm/haxe-modular.svg)](https://npmjs.org/package/haxe-modular)
[![Join the chat at https://gitter.im/haxe-react/haxe-modular](https://img.shields.io/badge/gitter-join%20chat-brightgreen.svg)](https://gitter.im/haxe-react/haxe-modular)Code splitting and hot-reload for Haxe JavaScript applications.
## Why?
If you use **Haxe for JavaScript**, directly or indirectly (React, OpenFl,...), then
you probably want to:- make your web app load instantly,
- make your HTML5 game load quicker,
- load sections / features / mini-games on-demand.Haxe has an excellent, compact and optimised JS output, but it's always a single file;
even with good minification / gzip compression it can be a large payload.*Modular can split gigantic Haxe-JS outputs into load-on-demand features,
without size/speed overhead, and without losing sourcemaps.*## How?
```haxe
import MyClass;
...
load(MyClass).then(function(_) {
var c = new MyClass();
});
```The approach is to *reference one class asynchronously* in your code:
- **at compile time**, the *dependency graph* of the class is built and one additional JS
file will be emitted (bundling this class and all its dependencies),
- **at run time**, when the aynchronous reference is evaluated, the additional JS is
loaded (once) automatically.## Where to start?
There are 2 ways to use Haxe Modular, depending on your project/toolchain/goals:
1. [standalone Modular](doc/start.md); zero dependencies, for any Haxe-JS project,
2. [Webpack Haxe Loader](https://github.com/jasononeil/webpack-haxe-loader);
leverage the famous JS toolchain.In both cases, it is advisable to read about the technical details:
- [How to extract/split whole libraries?](doc/libraries.md)
- [Using Reflection? Need more granular control of bundling?](doc/advanced.md)
- [How does on-demand loading work at run time?](doc/how.md)### What is the difference?
Both solutions:
- use Modular splitting under the hood,
- split automatically using a single `hxml` build configuration,
- support NPM dependencies,
- allow hot-reloading of code.### What should I use?
1. [Standalone Modular](doc/start.md) is an easy, drop-in, addition to a regular
Haxe JS build process - it is very lightweight and unobstrusive, and you don't need
to learn Webpack.Using NPM modules however requires a bit of ceremony: all the NPM dependencies have to
be gathered (manually) in a `libs.js` which is loaded upfront.2. [Webpack Haxe Loader](https://github.com/jasononeil/webpack-haxe-loader) is a more
powerful setup but you'll have to learn Webpack. Webpack is a complex and large system
offering vast possibilities from the JS ecosystem.### FAQ
Q: Where can I get more help? I have questions / issues...
- Join [haxe-modular chat on Gitter.im](https://gitter.im/haxe-react/haxe-modular)
Q: Is it only for React projects?
- **Of course not**; anything targeting JavaScript can use it.
- However it does offer React-specific additional features for code hot-reloading.Q: Is it possible to minify the code?
- **Yes**, with [Standalone Modular](doc/start.md) you can either minify each script
yourself, or use `uglifyjs` or `closure` haxelibs for that:
[releasing to production](doc/production-release.md).
- **Yes**, with [Webpack Haxe Loader](https://github.com/jasononeil/webpack-haxe-loader)
it will be taken care of by Webpack as part of the production build minification.Q: Can I extract a library/package from my code?
- **Yes**: [you can split libraries](doc/libraries.md), but for technical reasons,
extracting a library (e.g. many classes used across the application) has some limitations.Q: Can I still use the `includeFile` macro to inject JS code in the output?
- **Yes, but** only when the code is inserted at the top of the file; this is the
default position when using `--macro includeFile('my-lib.js')`.Q: Does it support Haxe 4's ES6 output? (`-D js-es=6`)
- **Yes** since 0.12.0