NodeJs and Ejs Pass Arrays to page

h00j picture h00j · May 12, 2013 · Viewed 17.7k times · Source

I am trying to pass an array to an .ejs page, however when I try use

var test ="<%= data %>";
console.log(test);

I get the output

[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object],[object Object

Console.log on the nodejs file works fine, but its when I try console.log client side it messes up.

Answer

Jonathan Lonowski picture Jonathan Lonowski · May 12, 2013

The issue is likely with <%= data %>, rather than console.log(). If you check the result client-side, you'll probably see:

var test ="[object Object],[object Object],[object Object],...";

When you simply print an Array, this will just .join() the elements, calling .toString() on each. And:

new Object().toString() === "[object Object]"

To output the data so it can be consumed, you can use JSON.stringify():

var test = <%- JSON.stringify(data) %>;

This takes advantage of JSON's syntax being based on JavaScript's synax to output an Array literal of Object literals:

var test = [{"prop":"value"},...];