Compatibility
Minecraft: Java Edition
Platforms
Supported environments
75% of ad revenue goes to creators
Support creators and Modrinth ad-free with Modrinth+Links
Creators
Details
EventJS
is a KubeJS addon that adds reloadable native events for KubeJS.
With EventJS, you can
- refresh your native event listeners without restarting the whole game or store the handler within a
global['someId']
, which is both simpler and more performant. - add/remove native event listeners as you like without relaunching, which was impossible in KubeJS for 1.16-1.20
- prevent your game from crashing if something goes wrong in your native event listener
- add event listener only in server/client side
Usage
By default, EventJS will replace the original native event listening method to make it reloadable. So you actually don't need to learn anything new in order to use EventJS, just install it and you Forge event listening is reloadable now.
But, if you're looking for some more dynamic and well-defined event listending, you can use NativeEvents.onEvent(...)
, and NativeEvents.onGenericEvent(...)
for generic event listening.
NativeEvents
will be avaliable for all 3 script types (client/server/startup), so you can perform sided event listening, that is, for example, listen to client-only event in client_scripts
, then this event listening will not happen on server side.
Syntax (v1.0.0~1.3.0)
NativeEvents.onEvent(eventType, handler)
NativeEvents.onEvent(priority, receiveCancelled, eventType, handler)
NativeEvents.onGenericEvent(genericClassFilter, eventType, handler)
NativeEvents.onGenericEvent(genericClassFilter, priority, receiveCancelled, eventType, handler)
The handler
in JS side, is a callback that receives the event, for example: (event) => {...}
The eventType
and genericClassType
is something that can represent a class, like a string that holds the event class name, or the event class itself loaded by java(...)
or Java.loadClass(...)
.
let handler: (event: AnyForgeEvent) => void
let eventType: string | Class
let genericClassFilter: string | Class
let priority: $EventPriority | "highest" | "high" | "normal" | "low" | "lowest"
let receiveCancelled: boolean
Changes in 1.4.0
In EventJS 1.4.0, in order to support ProbeJS Legacy out of the box, the eventType
and genericClassFilter
will only actively support Class
loaded via java(...)
(1.16.5) or Java.loadClass(...)
(1.20.1).
let eventType: Class
let genericClassFilter: Class
Supported Version
1.0.0: 1.16.5
1.1.0: 1.16.5, 1.20.1
1.2.0: all major version between 1.16 and 1.20
Do You Know That
The reason why I make this mod is that KubeJS is absurdly slow in implementing similar features. They added native event listener reloading only after KubeJS updated to 1.21, leaving all versions between 1.16~1.20 behind.
KubeJS for 1.21+ also contains support for native event listener reloading, using the same name NativeEvents
, but its implementation is not the same as EventJS, so please dont make assumptions when interacting EventJS internals via Java.