我正在尝试使用dart js使用Dart的绘图库JSXGraph,但出现问题。

这是有效的JavaScript代码

var board = JXG.JSXGraph.initBoard(
    'box',
    {
      boundingbox: [-10, 10, 2, -1],
      axis: true,
      keepaspectratio: false,
      showNavigation: false
    }
);
var graph = board.create(
    'functiongraph',
    [function(x){ return 3*x*x + 5*x + 1;}, -10, 10],
    {strokeColor: '#ffff00'}
);

您可以在jsFiddle上尝试here

我想做的基本上是相同的,但是是 Dart 。到目前为止,这是我想出的:

JsObject jsxGraph = context['JXG']['JSXGraph'];
var board = jsxGraph.callMethod('initBoard', [
  'box',
  new JsObject.jsify({
    'boundingbox': [-10, 10, 2, -1],
    'axis': true,
    'keepaspectratio': false,
    'showNavigation': false
  })
]);
var graph = board.callMethod('create', [
  'functiongraph',
  [(x){return 3*x*x + 5*x + 1;}, -10, 10],
  new JsObject.jsify({'strokeColor': '#ffff00'})
]);

我得到了绘图区域和坐标轴,但无法获得实际的绘图线。而是在控制台上出现错误:Uncaught TypeError: this.Y is not a function

有人可以指出我可能做错了什么吗?我怀疑这与回调函数有关,但我真的不知道。

最佳答案

您的代码中缺少jsify:

JsObject jsxGraph = context['JXG']['JSXGraph'];
var board = jsxGraph.callMethod('initBoard', [
  'box',
  new JsObject.jsify({
    'boundingbox': [-10, 10, 2, -1],
    'axis': true,
    'keepaspectratio': false,
    'showNavigation': false
  })
]);
var graph = board.callMethod('create', [
  'functiongraph',
  new JsObject.jsify([(x){return 3*x*x + 5*x + 1;}, -10, 10]},
  new JsObject.jsify({'strokeColor': '#ffff00'})
]);

09-25 17:52