最初のバージョンでは、 Dart オブジェクトへの参照を含むrecentlyUsedStations
js オブジェクトで設定された値で名前が付けられた js 変数を定義します。Js 側から見ると、この変数はほとんど使用できず、Dart オブジェクトの参照を保持するためにのみ使用する必要があります。このように、Dart オブジェクトは を呼び出して取得できます。DartObject
["Goetheplatz", "Marienplatz"]
context["recentlyUsedStations"]
なし new js.JsObject.jsify(...)
:
final a = ['b', 'c'];
js.context['a'] = a;
// unusable wrapper on Js side
// display : [object DartObject]
js.context['console'].callMethod('log', [js.context['a']]);
// the reference is kept
// display : true
print(identical(a, js.context['a']));
2 番目のバージョンは、同等の js array にrecentlyUsedStations
変換することによって作成された js オブジェクトで設定された値で名前が付けられた js 変数を定義します。このように、データは Js 側で使用できますが、元の Dart オブジェクトの参照は忘れられます。したがって、dart List に要素を追加しても、Js 側の配列には影響しません。["Goetheplatz", "Marienplatz"]
["Goetheplatz", "Marienplatz"]
と new js.JsObject.jsify(...)
:
final a = ['b', 'c'];
js.context['a'] = new js.JsObject.jsify(a);
// converted to an array on Js side
// display : [b,c]
js.context['console'].callMethod('log', [js.context['a']]);
// the reference has been forgotten
// display : false
print(identical(a, js.context['a']));
// adding an element on the original List has no effect on Js value
a.add('d');
js.context['console'].callMethod('log', [js.context['a']]); // b,c