![](/img/trans.png)
[英]How to produce a `ArrayBuffer` from `bytes` using `js_of_ocaml`
[英]How to invoke a function generated by js_of_ocaml?
我是JavaScript的新手,我正在尝试使用js_of_ocaml
。
我先写了一个非常简单的cubes.ml
:
let simple (a: int) =
a + 1234
然后遵守它:
ocamlfind ocamlc -package js_of_ocaml -package js_of_ocaml.syntax \
-syntax camlp4o -linkpkg -o cubes.byte cubes.ml
然后生成JavaScript文件:
js_of_ocaml cubes.byte
这是生成的cubes.js 。 需要注意的是,我们无法找到1234
或函数的名称simple
在该文件中。
我有另一个JavaScript文件Home.js
,我希望函数callSimple
调用在cubes.js
中生成的cubes.js
。 但我不知道如何写它。 有人可以帮忙吗?
(function () {
...
function callSimple(a) {
return ???;
};
...
})();
编辑1:
我尝试了@EdgarAroutiounian提出的解决方案:
(* cubes.ml *)
let () =
Js.Unsafe.global##.jscode := (object%js
val simple = Js.wrap_meth_callback
(fun a -> a + 1234)
val speak = Js.wrap_meth_callback
(fun () -> print_endline "hello")
end)
如果我在home.js
写:
confirm(jscode.simple(10)); // 1244 is expected
confirm(jscode.speak()); // "hello" as string is expected
第一行返回function (a){return p(c,aM(b,a))}
,第二行返回0
。 它们不是我所期望的。
这是一种可行的方法。
在我们旨在暴露给JavaScript的OCaml代码中:
let () =
Js.Unsafe.global##.jscode := (object%js
val simple = Js.wrap_meth_callback
(fun a -> a + 1234)
val speak = Js.wrap_meth_callback
(fun () -> print_endline "hello")
end)
请注意,我正在使用ppx
扩展名,我建议您也这样做:这意味着不再使用camlp4
。 您可以使用以下代码编译该代码
ocamlfind ocamlc -package js_of_ocaml.ppx -linkpkg cubes.ml -o T
js_of_ocaml T -o cubes.js
然后在你的另一个文件home.js
console.log(jscode.simple(10));
console.log(jscode.speak());
和index.html
:
<!DOCTYPE html>
<meta charset="utf-8">
<body>
<script src="cubes.js"></script>
<script src="home.js"></script>
</body>
那应该有用。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.