2012-12-18 5 views

Antwort

2

Viele Änderungen in API dieses Jahr durchgeführt wurde, folgenden Code ist die Antwort von Alexandre Ardhuin neuesten angepasst (# 30104) Dart Sdk

import "dart:convert"; 
import "dart:js" as js; 

convert(js.JsObject object) 
{ 
    return JSON.decode(js.context['JSON'].callMethod("stringify", [ object ])); 
} 
3

Sie könnten die integrierte JavaScript-Methode JSON.stringify() aus dem JavaScript-Kontext verwenden.

Future getManifest() { 
    var completer = new Completer(); 

    js.scoped(() { 
    var chrome = js.context.chrome; 
    var manifest_proxy = chrome.runtime.getManifest(); 
    var manifest_string = js.context.JSON.stringify(manifest_proxy); 
    var manifest = JSON.parse(manifest_string); 
    logger.fine("manifest_string = $manifest_string"); 
    completer.complete(manifest); 
    }); 

    return completer.future;  
} 

Welches würde die folgenden auf der Konsole ausdrucken und senden Sie dem Completer eine Dart Map.

manifest_string = {"app":{"background":{"scripts":["main.js"]}},"manifest_version":2,"minimum_chrome_version":"23","name":"chrome.dart - test","version":"1"} 
+1

Sie müssen keine 'Zukunft' verwenden. –

+0

Schön, so dass das Scoped keine zukünftige Rückkehr erfordert. In dieser Bibliothek habe ich Future als Muster für die meisten Anrufe von chrome verwendet. * Apis. Wenn dies der Fall ist, sollte ich Futures nur für Methoden benötigen, die Rückrufe erfordern. http://goo.gl/x2H2K –

4

Sie können eine Javascript JSON an einen Dart JSON konvertieren mit:

import 'dart:json'; 
import 'package:js/js.dart' as js; 

convert(js.Proxy jsonProxy) => JSON.parse(js.context.JSON.stringify(jsonProxy)); 
Verwandte Themen