2012-06-14 5 views
5

Ich protokollieren verschiedene Leistungsmetriken auf der Konsole (falls vorhanden). Dieser Inhalt wird am besten als Tabelle angezeigt, und die Methode console.table() von FireBug funktioniert hervorragend - aber die meisten meiner Nutzer sind in Chrome.Implementieren Firebug Konsole.Tabelle in Chrom

console.table() ist eine großartige Lösung, weil ich ein gut formatiertes Grid im UI-Stil erhalte, ohne eine dedizierte UI-Steuerung erstellen und warten zu müssen. Derzeit kann ich in Chrome nur unformatierten Text protokollieren.

Alternativ, wenn es einen Weg zu Render HTML-Inhalt in der Konsole gibt, würde das auch funktionieren. Ich kann HTML an die Konsole senden, aber es rendert als DOM-Inhalt in der Registerkarte Elemente. Ich weiß, der Inspektor ist nur HTML/JS/CSS - also ist es technisch möglich. Tatsächlich kann ich es tun, wenn ich den Inspektor inspiziere - aber das löst das Problem für die reale Welt nicht.

+0

Haben Sie darüber nachgedacht, eine eigene Chrome-Erweiterung zu erstellen? – Tadeck

+0

Es ist eine gültige Option, aber nicht alle Nutzer der App können dies tun. Der primäre Anwendungsfall ist: Ein Kunde denkt, dass die App langsam ist und ruft Support an. Der Support sagt: "Bitte öffne deine Konsole und kopiere/kopiere die Ergebnisse". Der Kunde kann oder kopiert nicht alles und der Support kann das Ergebnis validieren oder nicht. Ich bekomme dann eine E-Mail mit Leistungsdaten, die nicht das ganze Bild haben. Wenn es so in den Browser eingebacken ist, dass die Möglichkeit von Fehlern reduziert wird, ist das ideal. – Christopher

+0

Wenn Sie möchten, dass Sie es verwenden können, indem Sie den Inhalt des Benutzers abrufen, können Sie einfach 'JSON.stringify()' in Ihren Tabellendaten verwenden und dem Benutzer mitteilen, dass er es erhalten soll, in die E-Mail einfügen und senden. Nach Erhalt erhalten Sie nur deserialisierte Daten, es muss nicht einmal eine Tabelle sein. Gefällt das Ihnen? – Tadeck

Antwort

4

hatte ich das gleiche Problem und schrieb den Code unten. Es ist nicht so vollständig wie console.table, es akzeptiert nur ein Array von Datensätzen und nimmt keine Liste von Spalten. Die Ausgabe ist auch nicht so schön, aber es war genug für mich. Ein Beispiel:

$ console_table([{who:"World",message:"Hello"} 
       ,{who:"My wife",message:"Good Morning!"}]) 
|who |message  | 
|World |Hello  | 
|My wife|Good Morning!| 

Und der Code dahinter:

// Will be available in the latest Chrome, then I can delete this 
function console_table(xs) 
{ 
    if (xs.length === 0) 
     console.log("No data"); 
    else 
    { 
     var widths = []; 
     var cells = []; 
     for (var i = 0; i <= xs.length; i++) 
      cells.push([]); 
     for (var s in xs[0]) 
     { 
      var len = s.length; 
      cells[0].push(s); 
      for (var i = 0; i < xs.length; i++) 
      { 
       var ss = "" + xs[i][s]; 
       len = Math.max(len, ss.length); 
       cells[i+1].push(ss); 
      } 
      widths.push(len); 
     } 
     var s = ""; 
     for (var x = 0; x < cells.length; x++) 
     { 
      for (var y = 0; y < widths.length; y++) 
       s += "|" + pad(widths[y], cells[x][y]); 
      s += "|\n"; 
     } 
     console.log(s); 
    } 
} 

function pad(n,s) 
{ 
    var res = s; 
    for (var i = s.length; i < n; i++) 
     res += " "; 
    return res; 
} 
+0

+1 für einen nützlichen Hack, wenn auch nicht _precely_ eine Antwort auf die (etwas vage gebildete) Frage. –

0

bewegt Auflage nach innen

// Will be available in the latest Chrome, then I can delete this 
function console_table(xs) 
{ 

    function pad(n,s) 
    { 
     var res = s; 
     for (var i = s.length; i < n; i++) 
      res += " "; 
     return res; 
    } 

    if (xs.length === 0) 
     console.log("No data"); 
    else 
    { 
     var widths = []; 
     var cells = []; 
     for (var i = 0; i <= xs.length; i++) 
      cells.push([]); 
     for (var s in xs[0]) 
     { 
      var len = s.length; 
      cells[0].push(s); 
      for (var i = 0; i < xs.length; i++) 
      { 
       var ss = "" + xs[i][s]; 
       len = Math.max(len, ss.length); 
       cells[i+1].push(ss); 
      } 
      widths.push(len); 
     } 
     var s = ""; 
     for (var x = 0; x < cells.length; x++) 
     { 
      for (var y = 0; y < widths.length; y++) 
       s += "|" + pad(widths[y], cells[x][y]); 
      s += "|\n"; 
     } 
     console.log(s); 
    } 
} 
1

Es funktioniert auch in Chrome 31 und Firefox 25, wie von heute.

+0

Es wird NICHT in sauberem Firefox 25.0.1 unterstützt (vielleicht hast du es mit Firebug auf einer Seite versucht) – Victor