0

Dartのjsライブラリを使用してOpenLayersにアクセスしています。関連するコードは次のようになります。

js.scoped(() {
  ol = js.retain(js.context.OpenLayers);
  var max_extent = new js.Proxy(ol.Bounds, -13652354.432172, 6026153.418145, -13574082.915218, 6065289.1766216);
  var restricted_extent = max_extent;

  if (controls == null){

    var options = js.map ({
      'maxExtent': max_extent,
      'restrictedExtent' : restricted_extent,
      'units' : 'm',
      'projection': new js.Proxy(ol.Projection, 'EPSG:900913'),
      'displayProjection' : new js.Proxy(ol.Projection, 'EPSG:4326'),
      'controls' : js.array([ new js.Proxy(ol.Control.Attribution),
                              new js.Proxy(ol.Control.Navigation),
                              new js.Proxy(ol.Control.ArgParser),
                              new js.Proxy(ol.Control.PanPanel),
                              new js.Proxy(ol.Control.ZoomPanel)
                             ])
    });
    _treemap = js.retain( new js.Proxy( ol.Map, map_div_id, options ) );
  }

  var roads = new MapLayer(ol, layer_type:'road').layer;
  var aerial = new MapLayer(ol, layer_type:'hybrid').layer;

  _treemap.addLayers(js.array([roads, aerial]));
  _treemap.setBaseLayer(roads);
  _treemap.zoomToMaxExtent();
  var result = _treemap.layers();
});

最後の行を除いて、すべてが期待どおりに機能します。_treemap.layers()の配列を返すことになっていOpenLayer.Layerます。その行が実行されると、エラーが発生します。

例外:TypeError:オブジェクト[オブジェクト配列]にはメソッド'apply'がありません

では、Dartコードのjavascript関数から戻り値を取得/処理する正しい方法は何ですか?

4

1 に答える 1

1

layers配列です ( OpenLayers.Map.layersを参照)。したがって、次を使用する必要があります。

var result = _treemap.layers;

あなた_treemap.layers()はそれが関数だったので呼び出そうとしlayersていました。

コードに関する 1 つの補足事項: 使用する場合、またはオブジェクト ツリーでjs.map({})使用する必要はありません。単純にJSONのような構造を与えることができます。js.arrayjs.map

var options = js.map ({
  'maxExtent': max_extent,
  'restrictedExtent' : restricted_extent,
  'units' : 'm',
  'projection': new js.Proxy(ol.Projection, 'EPSG:900913'),
  'displayProjection' : new js.Proxy(ol.Projection, 'EPSG:4326'),
  'controls' : [ new js.Proxy(ol.Control.Attribution),
                 new js.Proxy(ol.Control.Navigation),
                 new js.Proxy(ol.Control.ArgParser),
                 new js.Proxy(ol.Control.PanPanel),
                 new js.Proxy(ol.Control.ZoomPanel)
               ])
});
于 2013-02-27T07:29:55.677 に答える