flutter_qjs
A quickjs engine for flutter.
Feature
This plugin is a simple js engine for flutter used quickjs project.
Each FlutterJs object create a new thread that running a simple js loop. A global async function dart is presented to invoke dart function, and Promise is supported in evaluating js script so that you can use await or then to get external result from dart.
Data convertion between dart and js are implemented as follow:
| dart | js |
|---|---|
| Bool | boolean |
| Int | number |
| Double | number |
| String | string |
| Uint8List/Int32List/Int64List | ArrayBuffer |
| Float64List | number[] |
| List | Array |
| Map | Object |
| Closure(List) => Future | function(....args) |
notice:
-
All the
Uint8List/Int32List/Int64Listsent from dart will be converted toArrayBufferwithout marked the size of elements, and theArrayBufferwill be converted toUint8List. -
functioncan only sent from js to dart and all the arguments will be packed in a dartListobject.
Getting Started
-
Creat a
FlutterJsobject. Makes sure callcloseto release memory when not need it. -
Call
setMethodHandlerto maintaindartfunction. -
Use
evaluateto evaluate js script. Makes sure surrounding try-cacth to capture evaluating error.
this contains a fully use of this plugin.
notice:
To use this plugin in Linux desktop application, you must change cxx_std_14 to cxx_std_17 in your project's CMakeLists.txt.