Over a million developers have joined DZone.
{{announcement.body}}
{{announcement.title}}

Printing JSON data on Node.js

DZone's Guide to

Printing JSON data on Node.js

· Web Dev Zone
Free Resource

Learn how to build modern digital experience apps with Crafter CMS. Download this eBook now. Brought to you in partnership with Crafter Software

Problem: If a data structure is too deeply nested, Node.js stops showing the details. This post presents two solutions.

Display a value as JSON data

Node.js stops displaying a data structure after two levels of nesting:
    > [[[ "test" ]]]
    [ [ [ 'test' ] ] ]

    > [[[[ "test" ]]]]
    [ [ [ [Object] ] ] ]
In this case [Object] stands for [ "test" ].

Option 1: a single line of JSON.

    > console.log("%j", [[[[ "test" ]]]]);
    [[[["test"]]]]
Option 2: Use JSON.stringify() [1] to print an indented tree.
    var tree = function(x) { console.log(JSON.stringify(x, null, 4)) };
    > tree([[[[ "test" ]]]]);
    [
        [
            [
                [
                    "test"
                ]
            ]
        ]
    ]
Warning: Anything non-JSONy will not be printed.
    > console.log("%j", { foo: function() {}, bar: "abc" })
    {"bar":"abc"}

Use util.inspect()

You can also use util.inspect(), but you need to specify that the nesting depth should be unlimited (the default is 2). It is also better not to show non-enumerable properties to avoid recursing into the properties of a function.

Option 1: Use util.inspect() directly.

    var util = require("util");
    > function ins(value) { console.log(util.inspect(value, false, null)); }

    > ins([[[[ "test" ]]]])
    [ [ [ [ 'test' ] ] ] ]

    > ins({ foo: function() {}, bar: "abc" });
    { foo: [Function], bar: 'abc' }

Option 2: Use console.dir(), which internally calls util.inspect(). Drawback: Stops after a nesting depth of 2.

    > console.dir([[[[ "test" ]]]])
    [ [ [ [Object] ] ] ]

    > console.dir({ foo: function() {}, bar: "abc" });
    { foo: [Function], bar: 'abc' }

Further reading

  1. JavaScript’s JSON API

Crafter is a modern CMS platform for building modern websites and content-rich digital experiences. Download this eBook now. Brought to you in partnership with Crafter Software.

Topics:

Opinions expressed by DZone contributors are their own.

The best of DZone straight to your inbox.

SEE AN EXAMPLE
Please provide a valid email address.

Thanks for subscribing!

Awesome! Check your inbox to verify your email so you can start receiving the latest in tech news and resources.
Subscribe

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}